JESD 21-C Section Title: Annex L: Serial Presence Detect (SPD) for DDR4 SDRAM Modules

Committee Document Reference Title: DDR4 SPD Document Release 5

**Device Type Identifier: UDIMM Revision 1.2** 

RDIMM Revision 1.3 LRDIMM Revision 1.4 NVDIMM-N Revision 1.2

# 1 Scope

This annex describes the serial presence detect (SPD) values for all DDR4 modules. The SPD data provides critical information about all modules on the memory channel and is intended to be use by the system's BIOS in order to properly initialize and optimize the system memory channels. The storage capacity of the SPD EEPROMs is limited, so a number of techniques are employed to optimize the use of these bytes, including overlays and run length limited coding.

All unused entries will be coded as 0x00. All unused bits in defined bytes will be coded as 0 except where noted.

Timing parameters in the SPD represent the operation of the module including all DRAMs and support devices at the lowest supported supply voltage (see SPD byte 11), and are valid from  $t_{CKAVG}$ min to  $t_{CKAVG}$ max (see SPD bytes 18 and 19).

To allow for maximum flexibility as devices evolve, SPD fields described in this document may support device configuration and timing options that are not included in the JEDEC DDR4 SDRAM data sheet (JESD79-4). Please refer to DRAM supplier data sheets or JESD79-4 to determine the compatibility of components.

# 2 History

Computer main memory buses have traditionally been defined by the generation of memory attached to the bus, e.g., EDO, SDRAM, DDR1, etc. The bus interface protocol and characteristics have largely been defined by the memory type. Clock frequency, CAS latencies, refresh recovery times and similar parameters defined the timing of signals between memory controller and the memory, and parameters such as number of ranks installed and device widths allowed system software to determine the memory capacity and similar high level characteristics of each module.

Over time, the memory bus has been extended to include additional features for application specific requirements. Registered DIMMs, for example, increased total capacity by buffering the loading of the address bus signals, allowing more DRAM to be installed. Similarly, Load Reduced DIMMs buffered the data bus as well, allowing even more ranks of memory to be supported. As each new extension to the function of the memory bus was introduced, system software combined knowledge of those extensions with information programmed into the EEPROM in the SPD to determine how to use and optimize the new features. Using the RDIMM as an example, systems understood than an additional clock of latency needed to be added to the DRAM latency to accommodate propagation delay through the register.

In later generations, the DRAM to host interface is completely virtualized. A memory module may have no DRAM at all, yet may use the DRAM bus to communicate with the host by emulating the DRAM channel interface. These virtual interfaces must appear to the system as one of the base module types, i.e., UDIMM, RDIMM, or LRDIMM. Modules that incorporate at least one non-DRAM media type for the purpose of main memory data storage are called "hybrid", they act like a DRAM but on the other side of the interface protocol are some other memory type(s).

#### 3 SPD Architecture

The SPD contents architecture must support the many variations of module types while remaining efficient. A system of overlay information selected through the use of "key bytes", or selectors for the type of information to load has been implemented. The following DDR4 module SPD address map describes where the individual lookup table entries will be held in the serial EEPROM.

Consistent with the definition of DDR4 generation SPD devices (EE1004 and TSE2004) which have four individual write protection blocks of 128 bytes in length each, the SPD contents are aligned with these blocks as shown in Table 1:

|       | Table 1 STD Contents At Cinetical |             |                                                                            |  |  |  |  |
|-------|-----------------------------------|-------------|----------------------------------------------------------------------------|--|--|--|--|
| Block | Range                             |             | Description                                                                |  |  |  |  |
| 0     | 0~127                             | 0x000~0x07F | Base Configuration and DRAM Parameters                                     |  |  |  |  |
| 1     | 128~191                           | 0x080~0x0BF | Standard Module Parameters See annexes L.1.x for details                   |  |  |  |  |
|       | 192~255 0x0C0~0x0FF               |             | Hybrid Module Parameters See annexes L.2.x for details                     |  |  |  |  |
| 2     | 256~319                           | 0x100~0x13F | Hybrid Module Extended Function Parameters - See Annexes L.3.x for details |  |  |  |  |
|       | 320~383                           | 0x140~0x17F | Manufacturing Information                                                  |  |  |  |  |
| 3     | 384~511                           | 0x180~0x1FF | End User Programmable                                                      |  |  |  |  |

Table 1 — SPD Contents Architecture

Operating parameters for the different module types are defined in the following subsections and will reside in the appropriate address ranges of the EEPROM address map depending on the module type. Please see Overlay Schema for further detail.

- 1. Section 9 Standard Module Parameter Overlay Bytes 128-191
  - Section 9.1 UDIMMs
  - Section 9.2 RDIMM
  - Section 9.3 LRDIMM
- 2. Section 10 Hybrid Module Parameters Overlay Bytes 192 255
  - Section 10.1 NVDIMM
- 3. Section 11 Hybrid Module Extended Function Parameters Overlay Bytes 256-319
  - Section 11.1 Energy Backed Byte Addressable NVDIMM
  - Section 11.2 Energy Backed Block Addressable NVDIMM
  - Section 11.3 Non-Energy Backed Byte Addressable NVDIMM

# 4 Overlay Schema

The following Schema exemplify the manner in which the base configuration information along with the appropriate subsections are to be overlaid onto the appropriate address spaces in order to provide a complete definition of the module.

# 4.1 UDIMM Overlay Schema

Table 2 shows the UDIMM overlay schema.

Key Byte 2 contains value 0x0C or 0x0E

Key Byte 3 contains any of the following values:

- 0x02, UDIMM
- 0x03, SO-DIMM
- 0x06, Mini-UDIMM
- 0x09, 72b-SO-UDIMM
- 0x0C, 16b-SO-DIMM
- 0x0D, 32b-SO-DIMM

| Block | Range   | Description                                        |  |
|-------|---------|----------------------------------------------------|--|
| 0     | 0~127   | Base Configuration and DRAM Parameters             |  |
| 1     | 128~191 | Insert Section 9.1: Unbuffered Memory Module Types |  |
|       | 192~255 | Unused                                             |  |
| 2     | 256~319 | Reserved                                           |  |
| 2     | 320~383 | Module Supplier's Data                             |  |
| 3     | 384~511 | End User Programmable                              |  |

Table 2 — UDIMM Overlay Schema

# 4.2 RDIMM Overlay Schema

Table 3 shows the RDIMM overlay schema.

Key Byte 2 contains value 0x0C or 0x0E

Key Byte 3 contains any of the following values:

- 0x01, RDIMM
- 0x05, Mini-RDIMM
- 0x08, 72b-SO-RDIMM

Table 3 — RDIMM Overlay Schema

| Block | Range   | Description                                   |
|-------|---------|-----------------------------------------------|
| 0     | 0~127   | Base Configuration and DRAM Parameters        |
| 1     | 128~191 | Insert Section 9.2: RDIMM Memory Module Types |
|       | 192~255 | Unused                                        |
| 2     | 256~319 | Reserved                                      |
| 2     | 320~383 | Module Supplier's Data                        |
| 3     | 384~511 | End User Programmable                         |

# 4.3 LRDIMM Overlay Schema

Table 4 shows the LRDIMM overlay schema.

Key Byte 2 contains value 0x0C or 0x0E

Key Byte 3 contains any of the following values:

• 0x04, LRDIMM

Table 4 — LRDIMM Overlay Schema

| Block | Range   | Description                                    |
|-------|---------|------------------------------------------------|
| 0     | 0~127   | Base Configuration and DRAM Parameters         |
| 1     | 128~191 | Insert Section 9.3: LRDIMM Memory Module Types |
|       | 192~255 | Unused                                         |
| 2     | 256~319 | Reserved                                       |
| 2     | 320~383 | Module Supplier's Data                         |
| 3     | 384~511 | End User Programmable                          |

## 4.4 Hybrid DIMM Overlay Schema

Table 5 shows the Hybrid DIMM overlay schema.

Key Byte 2 contains value 0x0C or 0x0E

Key Byte 3 contains any of the following values:

• 0x9M, NVDIMM - Non-volatile DIMM; M defines base architecture

| Block | Range   | Description                                          |
|-------|---------|------------------------------------------------------|
| 0     | 0~127   | Base Configuration and DRAM Parameters               |
| 1     | 128~191 | Insert Base Module Type Section 9.x                  |
|       | 192~255 | Insert Hybrid Memory Parameter Section 9.x           |
| 2     | 256~319 | Insert Extended Function Parameter Block Section 9.x |
| 2     | 320~383 | Module Supplier's Data                               |
| 3     | 384~511 | End User Programmable                                |

Table 5 — Hybrid DIMM Overlay Schema

After programming the SPD contents, suppliers of JEDEC compliant modules must set the write protect bits for SPD device blocks 0 and 1 and must not set the write protect bit for block 3. Write protection of block 2 is required for modules using the Extended Function Parameter Block, such as NVDIMMs. See the EE1004-v/TSE2004av Device Specification for details on the SWPn command protocol.

# 5 Parsing the SPD

Table 6 provides relevant SPD bytes for parsing.

SPD Byte(s) Definition 1 SPD revision for this memory module 2 DRAM interface type presented or emulated 3 Memory module interface type 0~127 Base configuration and DRAM parameters 128~191 Module specific parameters 192~255 Hybrid memory parameters 204~219 NVDIMM function interface descriptors 256~319 Extended function parameter block

Table 6 — Some Relevant SPD Bytes for Parsing

The system BIOS will acquire information from the SPD in order to properly configure the systems memory controller. It is assumed the BIOS will parse the SPD data in the order listed below.

#### Step 1: Parse Byte 2 - Verify the installed DRAM type is supported.

The first step in parsing the SPD is to verify that the DRAM type installed is supported by looking at DRAM device type byte 2. While it is usually not possible to physically plug in the wrong memory type, for example a DDR3 module size or key location should prevent insertion into a DDR4 system, there are cases where byte 2 is used to prevent accidental use of an incompatible memory type such as DDR4E modules in a DDR4-only system.

#### Step 2: Parse Byte 1 - Verify SPD compatibility. See Section 6 - SPD Revision Progression

The SPD revision byte 1 "encoding" nibble may be used to force legacy systems to reject newer modules. This would typically only occur if a critical error were found in SPD encoding that would require a "fix". In this case, as in the case of an unsupported DRAM type, system initialization must be halted immediately.

The SPD revision stored in Byte 1 applies to all information for the module, including base information, module specific information, and hybrid information. Each SPD revision exactly defines how many bytes are valid in all other SPD blocks. The number of supported bytes (or bits) may increase from one SPD revision to another within each block as indicated by the "additions" nibble of the SPD revision. For example, an SPD revision 1.3 has more bytes or bits defined than SPD revision 1.2.

This progression of SPD contents is important for the BIOS to DIMM compatibility model. An older system may have a BIOS that only understands SPD revision 1.2 encoding, so if a module is installed that contains revision 1.3 information, the system can accurately interpret all of the historical revision 1.2 information retained in the module that is the subset of the revision 1.3 specification. Similarly, if a module with SPD revision 1.1 information is installed, that same BIOS can interpret all information that was current at the time that SPD 1.1 was defined. Therefore, BIOSes must maintain a knowledge of the active information for each historical SPD revision in order to support older modules.

#### Step 3: Parse Byte 3 - Determine module type and appropriate overlays.

Key byte 3 for module type determines the subsequent use of overlay information. Byte 3 bits 3~0 define the host to module interface style: unbuffered, registered, or load reduced. Standard module types are defined in Annexes L.1.x.

Key byte 3 also determines the presence of hybrid module types. Byte 3, bit 7 asserts if the module is hybrid, and Byte 3, bits 6~4 define the type of hybrid module. A hybrid module may appear to the system as a superset of any of the base module types. For example, an NVDIMM may present a UDIMM, RDIMM, or LRDIMM compatible interface to the system. Because of this unique second overlay for hybrid information on top of the base module type, the SPD revision for Hybrid modules must include all relevant information for any of the base module types if applicable. Refer to SPD revision progression in Section 6 for more information.

If Byte 3, bits 7~4 indicate the presence of a Hybrid module type, the BIOS must parse two more overlays. Annex L.2, Hybrid Module Parameters (Bytes 192~255) and Section 11 Hybrid Modules Extended Function Parameters (Bytes 256~319). As with the module specific parameters, both of the Hybrid Module parameter sets may increase from SPD revision to revision.

#### Step 4: Parse Bytes 0-127 - Make base configuration settings to memory interface based on these bytes.

All module types are required to read and interpret this block of data to set up the DRAM type, maximum operating frequency, the number of row, column, bank bits, write recovery time, etc. While these bytes primarily describe the timing of the DRAMs, timing represents the capabilities of the module and it may be necessary to downgrade the timing based on other factors including layout or support components on the module, such as registers.

#### Step 5: Parse Bytes 128-191 - Configure Standard module memory interface.

These bytes will be referenced and used by the system as needed based on the Standard module type that was determined after Byte 3 was parsed as indicated in Step 2. Bytes 128~191 are coded differently for each standard module type as defined in Section 9.

#### Step 6: Parse Bytes 192-255 (If Hybrid) - Read Hybrid Module parameters settings.

These bytes will be referenced and used by the system as needed based on the Hybrid module type that was determined after Byte 3 was parsed as indicated in Step 2. Function Format Interface Descriptors defined in bytes 204~205 through 218~219 will be read and utilized as indicated in Step 7. Bytes 192~255 are coded differently for each Hybrid module type and defined in Section 10.

#### Step 7: Parse Bytes 256-319 (If Hybrid Extended Functions are specified).

These bytes will be referenced and used by the system as needed based on the Function Format interface descriptors read previously during Step 6 from SPD bytes 204~205 through 218~219. Support up to 8 functions per Hybrid module can be defined within Bytes 256~319 and are coded based on Section 11.

For NVDIMM hybrid modules, parsing the two data blocks of hybrid memory parameters in SPD bytes  $192\sim255$  and the extended function parameters in SPD bytes  $256\sim319$  is intimately related. Each function descriptor contains a 4-bit field in bits  $13\sim10$  that creates an address pointer into the extended function parameter block. The formula is: 256+4\* function descriptor bits  $13\sim10$ .

The extended function parameter blocks are run length limited, meaning that when one function parameter set stops the next set starts

#### 5 Parsing the SPD (Cont'd)

(with a granularity of 4 bytes). For example, imagine an NVDIMM with two functions, the first function is a byte addressable energy backed memory which requires 14 bytes of extended parameters and the second function is block addressed requiring 23 bytes of extended parameters. The resulting encoding for that NVDIMM are shown in Table 7:

| Definition                              |
|-----------------------------------------|
|                                         |
| sable energy backed                     |
| energy backed protocol                  |
| n parameters = 256 + 4 * <b>0</b> = 256 |
| ssed                                    |
| rotocol                                 |
| n parameters = 256 + 4 * <b>4</b> = 272 |
| byte addressed energy backed function   |
| block addressed function                |
| e<br>r                                  |

Table 7 — Example with Imaginary SPD Revision 1.2

The example in Table 7 assumes a certain SPD revision in order for the BIOS to know how many bytes are defined in the extended function parameter fields. If the above example were for SPD revision 1.2, then SPD revision 1.3 is released with 18 bytes for the first function and 26 bytes for the second function, the coding would change as shown in Table 8:

| SPD Bytes | Coding (binary)              | Definition                                                    |
|-----------|------------------------------|---------------------------------------------------------------|
| 204~205   | 1000 0000 0000 0001          | Implemented; byte addressable energy backed                   |
|           |                              | JEDEC byte addressable energy backed protocol                 |
|           |                              | Offset of extended function parameters = 256 +4 * 0 = 256     |
| 206~207   | 10 <b>01 01</b> 00 0100 0001 | Implemented; block addressed                                  |
|           |                              | JEDEC block addressed protocol                                |
|           |                              | Offset of extended function parameters = 256 + 4 * 5 = 276    |
| 256~273   | <valid></valid>              | Extended parameters for byte addressed energy backed function |
| 276~301   | <valid></valid>              | Extended parameters for block addressed function              |

Table 8 — Example with Imaginary SPD Revision 1.3

When an NVDIMM with SPD revision 1.3 is plugged into a legacy system written for SPD 1.2 or less, the BIOS would interpret the first 14 bytes of extended parameters for the byte addressed energy backed function (256~269) and the first 23 bytes of the block addressed function (276~294). The rest of the parameter bytes are ignored.

A newer system that supports SPD revisions up through 1.3 would interpret all bytes on either NVDIMM type in the correct SPD byte addresses, knowing that an NVDIMM with SPD revision 1.2 would have parameters in 256~269 and 272~294, and an NVDIMM with SPD revision 1.3 would have parameters in bytes 256~273 and 276~301.

# 6 SPD Revision Progression

The use of indexing for functional overlays creates a set of dependencies that affect how SPD revisions must be defined. All module types are dependent on the definition of the general DRAM section bytes 0~127, therefore any change in the general DRAM section requires an increase in the SPD revision for all module types UDIMM, RDIMM, LRDIMM and Hybrid DIMM.

A change in the indexed overlay information for specific module types does not require that the SPD revision for the other module types change. For example, adding information to an RDIMM 1.1 SPD specification would require increasing the RDIMM SPD specification to 1.2, however it would not affect UDIMM, LRDIMM or Hybrid DIMM SPD revisions.

Since hybrid modules may be implemented emulating any module type interface, then any change in the general DRAM section 0~127 or any change in any module type specific information 128~191 does require an increase in the NVDIMM SPD revision level. Since all NVDIMM types share a single overlay 192~255 and 256~319, a change in any NVDIMM SPD revision changes the revision for all NVDIMM types even if nothing changes for a specific NVDIMM type. Table 9 shows a hypothetical sequence starting from all module types at revision 1.0, then showing how SPD revisions would change based on certain actions.

Table 9 — Hypothetical SPD Revision Progression Showing Revision Relationships

| Event                               | UDIMM | RDIMM | LRDIMM | NVDIMM |
|-------------------------------------|-------|-------|--------|--------|
| Initial SPD release                 | 1.0   | 1.0   | 1.0    | 1.0    |
| Addition in RDIMM Annex             | 1.0   | 1.1   | 1.0    | 1.1    |
| Addition in LRDIMM Annex            | 1.0   | 1.1   | 1.1    | 1.2    |
| Addition in LRDIMM Annex            | 1.0   | 1.1   | 1.2    | 1.3    |
| Addition in General Section         | 1.1   | 1.2   | 1.3    | 1.4    |
| Addition in UDIMM Annex             | 1.2   | 1.2   | 1.3    | 1.5    |
| Addition in NVDIMM Annex            | 1.2   | 1.2   | 1.3    | 1.6    |
| Addition in RDIMM and UDIMM Annexes | 1.3   | 1.3   | 1.3    | 1.7    |
| Encoding change in LRDIMM Annex     | 1.3   | 1.3   | 2.3    | 2.7    |
| Addition in LRDIMM Annex            | 1.3   | 1.3   | 2.4    | 2.8    |
| Encoding change in General Section  | 2.3   | 2.3   | 3.4    | 3.8    |
| Addition in RDIMM Annex             | 2.3   | 2.4   | 3.4    | 3.9    |

#### 7 **Address Map**

This section provides the SPD address map for all DDR4 modules. It describes where the individual lookup table entries will be held in the serial EEPROM. Consistent with the definition of DDR4 generation SPD devices which have four individual write protection blocks of 128 bytes in length each, the SPD contents are aligned with these blocks as shown in Table 10:

Table 10 — Address Map

| Block | Range               |             | Description                                        |
|-------|---------------------|-------------|----------------------------------------------------|
| 0     | 0~127               | 0x000~0x07F | Base Configuration and DRAM Parameters             |
| 1     | 128~191             | 0x080~0x0BF | Module Specific Parameters See annexes for details |
| '     | 192~255             | 0x0C0~0x0FF | Hybrid Memory Parameters See annexes for details   |
| 2     | 256~319             | 0x100~0x13F | Extended Function Parameter Block                  |
|       | 320~383             | 0x140~0x17F | Manufacturing Information                          |
| 3     | 384~511 0x180~0x1FF |             | End User Programmable                              |

After programming the SPD contents, suppliers of JEDEC compliant modules must set the write protect bits for SPD device blocks 0 and 1 and must not set the write protect bit for block 3. Write protection of block 2 is required for modules using the Extended Function Parameter Block, such as NVDIMMs. See the EE1004-v/TSE2004av Device Specification for details on the SWPn command protocol.

#### 7.1 **Block 0: Base Configuration and DRAM Parameters**

Table 11 details the location of each byte in this block.

Table 11 — Block 0: Base Configuration and DRAM Parameters

| Byte Number |       | Function Described                                  | Notes |
|-------------|-------|-----------------------------------------------------|-------|
| 0           | 0x000 | Number of Serial PD Bytes Written / SPD Device Size | 1, 2  |
| 1           | 0x001 | SPD Revision                                        |       |
| 2           | 0x002 | Key Byte / DRAM Device Type                         |       |
| 3           | 0x003 | Key Byte / Module Type                              |       |

NOTE 1 Number of SPD bytes written will typically be programmed as 384 bytes.

NOTE 2 Size of SPD device will typically be programmed as 512 bytes.

NOTE 3 From DDR4 SDRAM datasheet.

Table 11 — Block 0: Base Configuration and DRAM Parameters (Cont'd)

| Byte | e Number | Function Described                                                                        | Notes |
|------|----------|-------------------------------------------------------------------------------------------|-------|
| 4    | 0x004    | SDRAM Density and Banks                                                                   | 3     |
| 5    | 0x005    | SDRAM Addressing                                                                          | 3     |
| 6    | 0x006    | Primary SDRAM Package Type                                                                | 3     |
| 7    | 0x007    | SDRAM Optional Features                                                                   | 3     |
| 8    | 0x008    | SDRAM Thermal and Refresh Options                                                         | 3     |
| 9    | 0x009    | Other SDRAM Optional Features                                                             | 3     |
| 10   | 0x00A    | Secondary SDRAM Package Type                                                              | 3     |
| 11   | 0x00B    | Module Nominal Voltage, VDD                                                               | 3     |
| 12   | 0x00C    | Module Organization                                                                       |       |
| 13   | 0x00D    | Module Memory Bus Width                                                                   |       |
| 14   | 0x00E    | Module Thermal Sensor                                                                     |       |
| 15   | 0x00F    | Extended module type                                                                      |       |
| 16   | 0x010    | Reserved must be coded as 0x00                                                            |       |
| 17   | 0x011    | Timebases                                                                                 |       |
| 18   | 0x012    | SDRAM Minimum Cycle Time (t <sub>CKAVG</sub> min)                                         | 3     |
| 19   | 0x013    | SDRAM Maximum Cycle Time (t <sub>CKAVG</sub> max)                                         | 3     |
| 20   | 0x014    | CAS Latencies Supported, First Byte                                                       | 3     |
| 21   | 0x015    | CAS Latencies Supported, Second Byte                                                      | 3     |
| 22   | 0x016    | CAS Latencies Supported, Third Byte                                                       | 3     |
| 23   | 0x017    | CAS Latencies Supported, Fourth Byte                                                      | 3     |
| 24   | 0x018    | Minimum CAS Latency Time (t <sub>AA</sub> min)                                            | 3     |
| 25   | 0x019    | Minimum RAS to CAS Delay Time (t <sub>RCD</sub> min)                                      | 3     |
| 26   | 0x01A    | Minimum Row Precharge Delay Time (t <sub>RP</sub> min)                                    | 3     |
| 27   | 0x01B    | Upper Nibbles for t <sub>RAS</sub> min and t <sub>RC</sub> min                            | 3     |
| 28   | 0x01C    | Minimum Active to Precharge Delay Time (t <sub>RAS</sub> min), Least Significant Byte     | 3     |
| 29   | 0x01D    | Minimum Active to Active/Refresh Delay Time (t <sub>RC</sub> min), Least Significant Byte | 3     |
| 30   | 0x01E    | Minimum Refresh Recovery Delay Time (t <sub>RFC1</sub> min), Least Significant Byte       | 3     |
| 31   | 0x01F    | Minimum Refresh Recovery Delay Time (t <sub>RFC1</sub> min), Most Significant Byte        | 3     |
| 32   | 0x020    | Minimum Refresh Recovery Delay Time (t <sub>RFC2</sub> min), Least Significant Byte       | 3     |
| 33   | 0x021    | Minimum Refresh Recovery Delay Time (t <sub>RFC2</sub> min), Most Significant Byte        | 3     |
| 34   | 0x022    | Minimum Refresh Recovery Delay Time (t <sub>RFC4</sub> min), Least Significant Byte       | 3     |
| 35   | 0x023    | Minimum Refresh Recovery Delay Time (t <sub>RFC4</sub> min), Most Significant Byte        | 3     |
| 36   | 0x024    | Minimum Four Activate Window Time (t <sub>FAW</sub> min), Most Significant Nibble         | 3     |
| 37   | 0x025    | Minimum Four Activate Window Time (t <sub>FAW</sub> min), Least Significant Byte          | 3     |
| 38   | 0x026    | Minimum Activate to Activate Delay Time (t <sub>RRD_S</sub> min), different bank group    | 3     |
| 39   | 0x027    | Minimum Activate to Activate Delay Time (t <sub>RRD_L</sub> min), same bank group         | 3     |
| 40   | 0x28     | Minimum CAS to CAS Delay Time (t <sub>CCD_L</sub> min), same bank group                   | 3     |
| 41   | 0x29     | Upper Nibble for t <sub>WR</sub> min                                                      | 3     |
|      |          |                                                                                           | •     |

NOTE 1 Number of SPD bytes written will typically be programmed as 384 bytes.

NOTE 2 Size of SPD device will typically be programmed as 512 bytes.

NOTE 3 From DDR4 SDRAM datasheet.

|        |             | Block of Buse Configuration and Blatter I arameters (Cont a)                                           | 1 |
|--------|-------------|--------------------------------------------------------------------------------------------------------|---|
| Byt    | e Number    | Function Described                                                                                     |   |
| 42     | 0x2A        | Minimum Write Recovery Time (t <sub>WR</sub> min), Least Significant Byte                              | 3 |
| 43     | 0x2B        | Upper nibbles for t <sub>WTR</sub> min                                                                 | 3 |
| 44     | 0x02C       | Minimum Write to Read Time ( $t_{WTR\_S}$ min), different bank group, Least Significant Byte           | 3 |
| 45     | 0x02D       | Minimum Write to Read Time (t <sub>WTR_L</sub> min), same bank group, Least Significant Byte           | 3 |
| 46~59  | 0x02E~0x03B | Reserved must be coded as 0x00                                                                         |   |
| 60~77  | 0x03C~0x04D | Connector to SDRAM Bit Mapping                                                                         |   |
| 78~116 | 0x04E~0x074 | Reserved must be coded as 0x00                                                                         |   |
| 117    | 0x75        | Fine Offset for Minimum CAS to CAS Delay Time (t <sub>CCD_L</sub> min), same bank group                |   |
| 118    | 0x76        | Fine Offset for Minimum Activate to Activate Delay Time (t <sub>RRD_L</sub> min), same bank group      | 3 |
| 119    | 0x77        | Fine Offset for Minimum Activate to Activate Delay Time (t <sub>RRD_S</sub> min), different bank group | 3 |
| 120    | 0x078       | Fine Offset for Minimum Activate to Activate/Refresh Delay Time (t <sub>RC</sub> min)                  | 3 |
| 121    | 0x079       | Fine Offset for Minimum Row Precharge Delay Time (t <sub>RP</sub> min)                                 | 3 |
| 122    | 0x07A       | Fine Offset for Minimum RAS to CAS Delay Time (t <sub>RCD</sub> min)                                   | 3 |
| 123    | 0x07B       | Fine Offset for Minimum CAS Latency Time (t <sub>AA</sub> min)                                         | 3 |
| 124    | 0x07C       | Fine Offset for SDRAM Maximum Cycle Time (t <sub>CKAVG</sub> max)                                      | 3 |
| 125    | 0x07D       | Fine Offset for SDRAM Minimum Cycle Time (t <sub>CKAVG</sub> min)                                      | 3 |
| 126    | 0x07E       | CRC for Base Configuration Section, Least Significant Byte                                             |   |
| 127    | 0x07F       | CRC for Base Configuration Section, Most Significant Byte                                              |   |

Table 11 — Block 0: Base Configuration and DRAM Parameters (Cont'd)

#### 7.2 Block 1, lower half: Module Specific Parameters

Bytes 128~191 (0x080~0x0BF) Parameters in this block are specific to the module type as selected by the contents of SPD Key Byte 3 bits 3~0. Refer to the appropriate subsection for detailed byte descriptions.

# 7.3 Block 1, upper half: Hybrid Memory Parameters

Bytes 192~255 (0x0C0~0x0FF) Parameters in this block are specific to the hybrid memory type as selected by the contents of SPD Key Byte 3 bits 7~4. Refer to the appropriate subsection for detailed byte descriptions. The CRC field in bytes 254~255 covers all of block 1, bytes 128~255.

#### 7.4 Block 2, lower half: Extended Function Parameters

Bytes 256~319 (0x100~0x13F). Parameters in this block are used to define the extended functions available on Hybrid modules. Values in this block are based on indices in the NVDIMM annex, and the size of each function parameter block is unique to that function type.

NOTE 1 Number of SPD bytes written will typically be programmed as 384 bytes.

NOTE 2 Size of SPD device will typically be programmed as 512 bytes.

NOTE 3 From DDR4 SDRAM datasheet.

#### 7.5 Block 2, upper half: Manufacturing Information

Bytes  $320 \sim 383$  (0x140 $\sim$ 0x17F) Table 12 details the location of each byte in this block.

Table 12 — Block 2, upper half: Manufacturing Information

| Byte Number |             | Function Described                         | Notes |
|-------------|-------------|--------------------------------------------|-------|
| 320         | 0x140       | Module Manufacturer's ID Code, First Byte  |       |
| 321         | 0x141       | Module Manufacturer's ID Code, Second Byte |       |
| 322         | 0x142       | Module Manufacturing Location              |       |
| 323~324     | 0x143~0x144 | Module Manufacturing Date                  |       |
| 325~328     | 0x145~0x148 | Module Serial Number                       |       |
| 329~348     | 0x149~0x15C | Module Part Number                         |       |
| 349         | 0x15D       | Module Revision Code                       |       |
| 350         | 0x15E       | DRAM Manufacturer's ID Code, First Byte    |       |
| 351         | 0x15F       | RAM Manufacturer's ID Code, Second Byte    |       |
| 352         | 0x160       | DRAM Stepping                              |       |
| 353~381     | 0x161~0x17D | Module Manufacturer's Specific Data        |       |
| 382~383     | 0x17E~0x17F | Reserved; must be coded as 0x00            |       |

## 7.6 Block 3: End User Programmable

Bytes 384~511 (0x180~0x1FF) Bytes in this block are reserved for use by end users.

# 8 Details of Each Byte

# 8.1 General Configuration Section: Bytes 0~127 (0x000~0x07F)

This section defines parameters that are common to all DDR4 module types.

#### 8.1.1 Byte 0 (0x000): Number of Bytes Used / Number of Bytes in SPD Device

The least significant nibble of this byte, shown in Table 13, describes the total number of bytes used by the module manufacturer for the SPD data and any (optional) specific supplier information. The byte count includes the fields for all required and optional data. Bits 6~4 describe the total size of the serial memory used to hold the Serial Presence Detect data.

Table 13 — Byte 0 (0x000): Number of Bytes Used / Number of Bytes in SPD Device

| Bit 7                                                          | Bits 6~4                                                               | Bits 3~0                                                                                                 |  |  |  |
|----------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--|--|--|
| Reserved                                                       | SPD Bytes Total                                                        | SPD Bytes Used                                                                                           |  |  |  |
| Reserved; must be coded as 0                                   | Bit [6, 5, 4]: 000 = Undefined 001 = 256 010 = 512 All others reserved | Bit [3, 2, 1, 0]:  0000 = Undefined  0001 = 128  0010 = 256  0011 = 384  0100 = 512  All others reserved |  |  |  |
| NOTE Typical programming of bits 3~0 will be 0011 (384 bytes). |                                                                        |                                                                                                          |  |  |  |

#### 8.1.2 Byte 1 (0x001): SPD Revision

This byte, shown in Table 14, describes the compatibility level of the encoding of the bytes contained in the SPD EEPROM, and the current collection of valid defined bytes. Software should examine the upper nibble (Encoding Level) to determine if it can correctly interpret the contents of the module SPD. The lower nibble (Additions Level) can optionally be used to determine which additional bytes or attribute bits have been defined; however, since any undefined additional byte must be encoded as 0x00 or undefined

attribute bit must be defined as 0, software can safely detect additional bytes and use safe defaults if a zero encoding is read for these bytes.

|                   |              | Encoding Level |          |          | Additions Level |          |          |          |          |     |
|-------------------|--------------|----------------|----------|----------|-----------------|----------|----------|----------|----------|-----|
| Production Status | SPD Revision | Bit<br>7       | Bit<br>6 | Bit<br>5 | Bit<br>4        | Bit<br>3 | Bit<br>2 | Bit<br>1 | Bit<br>0 | Hex |
|                   | Revision 0.0 | 0              | 0        | 0        | 0               | 0        | 0        | 0        | 0        | 00  |
| Pre-production    | Revision 0.1 | 0              | 0        | 0        | 0               | 0        | 0        | 0        | 1        | 01  |
|                   |              | -              | -        | -        | -               | -        | -        | -        | -        |     |
|                   | Revision 0.9 | 0              | 0        | 0        | 0               | 1        | 0        | 0        | 1        | 09  |
|                   | Revision 1.0 | 0              | 0        | 0        | 1               | 0        | 0        | 0        | 0        | 10  |
| Production        | Revision 1.1 | 0              | 0        | 0        | 1               | 0        | 0        | 0        | 1        | 11  |
|                   |              | -              | -        | -        | -               | -        | -        | -        | -        |     |
| Undefined         | Undefined    | 1              | 1        | 1        | 1               | 1        | 1        | 1        | 1        | FF  |

Table 14 — Byte 1 (0x001): SPD Revision

The Additions Level is never reduced even after an increment of the Encoding Level. For example, if the current SPD revision level were 1.2 and a change in Encoding Level were approved, the next revision level would be 2.2. If additions to revision 2.2 were approved, the next revision would be 2.3. Changes in the Encoding Level are extremely rare, however, since they can create incompatibilities with older systems.

The exceptions to the above rule are the SPD revision levels used during development prior to the Revision 1.0 release. Revisions 0.0 through 0.9 are used to indicate sequential pre-production SPD revision levels, however the first production release will be Revision 1.0.

This document defines the SPD contents for multiple families of DDR4 memory modules, with a separate section for each family that defines the bytes in SPD locations 128~255 (0x080~0x0FF). These module families and their respective sections are:

- Section 9.1: Unbuffered Memory Modules
- Section 9.2: Registered Memory Modules
- Section 9.3: Load Reduced Memory Modules
- Section 10.1: Non-Volatile Memory Modules

The SPD revision level for each module family type is independent. This allows changes to be made to the Registered DIMM annex, for example, without necessarily changing the revision of Unbuffered DIMMs. In this context, the SPD revision value corresponds to all SPD bytes for that DIMM type. It also means that over time, the revisions for each module type may vary. Note that changes to a DIMM specific annex does not affect the revisions of other module types, but changes in the General Section of the SPD affect all DIMM types. The example in Table 15 suggests a possible historical progression:

Table 15 — Hypothetical Historic Progression of SPD Revisions by DIMM Type

| Event                       | UDIMM | RDIMM | LRDIMM |
|-----------------------------|-------|-------|--------|
| Initial SPD release         | 1.0   | 1.0   | 1.0    |
| Addition in RDIMM Annex     | 1.0   | 1.1   | 1.0    |
| Addition in LRDIMM Annex    | 1.0   | 1.1   | 1.1    |
| Addition in LRDIMM Annex    | 1.0   | 1.1   | 1.2    |
| Addition in General Section | 1.1   | 1.2   | 1.3    |
| Addition in UDIMM Annex     | 1.2   | 1.2   | 1.3    |

Table 15 — Hypothetical Historic Progression of SPD Revisions by DIMM Type (Cont'd)

| Event                              | UDIMM | RDIMM | LRDIMM |
|------------------------------------|-------|-------|--------|
| Encoding change in LRDIMM Annex    | 1.2   | 1.2   | 2.3    |
| Addition in LRDIMM Annex           | 1.2   | 1.2   | 2.4    |
| Encoding change in General Section | 2.2   | 2.2   | 3.4    |
| Addition in RDIMM Annex            | 2.2   | 2.3   | 3.4    |

#### 8.1.3 Byte 2 (0x002): Key Byte / DRAM Device Type

This byte, shown in Table 16, is the key byte used by the system BIOS to determine how to interpret all other bytes in the SPD EEPROM. The BIOS must check this byte first to ensure that the EEPROM data is interpreted correctly. Any DRAM or Module type that requires significant changes to the SPD format (beyond defining previously undefined bytes or bits) also requires a new entry in the key byte table below.

Table 16 — Byte 2 (0x002): Key Byte / DRAM Device Type

| Line<br># | Hex | SDRAM / Module Type Corresponding to Key Byte |
|-----------|-----|-----------------------------------------------|
| 0         | 00  | Reserved                                      |
| 1         | 01  | Fast Page Mode                                |
| 2         | 02  | EDO                                           |
| 3         | 03  | Pipelined Nibble                              |
| 4         | 04  | SDRAM                                         |
| 5         | 05  | ROM                                           |
| 6         | 06  | DDR SGRAM                                     |
| 7         | 07  | DDR SDRAM                                     |
| 8         | 08  | DDR2 SDRAM                                    |
| 9         | 09  | DDR2 SDRAM FB-DIMM                            |
| 10        | 0A  | DDR2 SDRAM FB-DIMM PROBE                      |
| 11        | 0B  | DDR3 SDRAM                                    |
| 12        | 0C  | DDR4 SDRAM                                    |
| 13        | 0D  | Reserved                                      |
| 14        | 0E  | DDR4E SDRAM                                   |
| 15        | 0F  | LPDDR3 SDRAM                                  |
| 16        | 10  | LPDDR4 SDRAM                                  |
| 17        | 11  | LPDDR4X SDRAM                                 |
| 18        | 12  | DDR5 SDRAM                                    |
| 19        | 13  | LPDDR5 SDRAM                                  |
| -         | •   | -                                             |
| 253       | FD  | Reserved                                      |
| 254       | FE  | Reserved                                      |
| 255       | FF  | Reserved                                      |

The DRAM Device Type byte defines an interface compatibility family more than it identifies a specific memory device. For example, where an unbuffered memory module may expose the devices directly to the edge connector contacts, a load reduced memory module presents the interfaces of registering clock drivers and data buffers to the edge connector contacts. There may be memory modules with completely different devices, such as non-volatile memories, however these may define themselves as a base memory type such as DDR4 SDRAM for interface compatibility with the memory controller. The memory controller must be aware of its capabilities when parsing the SPD.

#### 8.1.4 Byte 3 (0x003): Key Byte / Module Type

This byte, shown in Table 17, is a Key Byte used to index the module specific section of the SPD from bytes 128~191 and bytes 192~255. Byte 3 bits 3~0 identifies the SDRAM memory module type.

Bits 7~4 identifies the architecture of the secondary memory type, if any, present on the module in addition to the base DRAM. These secondary hybrid architectures may apply to any Base Module Type. The index in bits 7~4 are used to index the hybrid memory architecture specific section of the SPD from bytes 192~255.

System software supporting hybrid memory modules should parse the DRAM attributes per the Base Module Type and combine the indexed information per the Hybrid Memory Type to determine the combined memory module capabilities.

Some modules may have no base memory, but will have only a secondary memory type. For example, a Flash-only memory module. These are classified as "hybrid" for the purposes of interpreting the SPD. Where base memory parameters apply to this class of hybrid module, these will be documented with those bytes in the base section. Extended parameters are encoded in SPD bytes 192~255.

Bit 7 Bits 6~4 Bits 3~0 Hybrid **Hybrid Media Base Module Type** Bits [6, 5, 4]: 0 = Not hybrid Bits [3, 2, 1, 0]: (Module is DRAM only) 000 = Not hybrid 0000 = Extended DIMM type, see byte 15 (0x00F) 1 = Hybrid module 001 = NVDIMM Hybrid 0001 = RDIMM(See bits 6~4 for hybrid type) 010 = NVDIMM-P Hybrid 0010 = UDIMM 011 = NVDIMM-H Hybrid 0011 = SO-DIMM All other codes reserved 0100 = LRDIMM 0101 = Mini-RDIMM 0110 = Mini-UDIMM 0111 = Reserved 1000 = 72b-SO-RDIMM 1001 = 72b-SO-UDIMM 1010 = Reserved 1011 - Reserved 1100 = 16b-SO-DIMM 1101 = 32b-SO-DIMM 1110 = Reserved 1111 = Reserved

Table 17 — Byte 3 (0x003): Key Byte / Module Type

Base Module Type Definitions:

RDIMM: Registered Dual In-Line Memory Module UDIMM: Unbuffered Dual In-Line Memory Module

SO-DIMM: Unbuffered Small Outline Dual In-Line Memory Module, 64-bit data bus

LRDIMM: Load Reduced Dual In-Line Memory Module Mini-RDIMM: Mini Registered Dual In-Line Memory Module Mini-UDIMM: Mini Unbuffered Dual In-Line Memory Module

72b-SO-RDIMM: Small Outline Registered Dual In-Line Memory Module, 72-bit data bus 72b-SO-UDIMM: Small Outline Unbuffered Dual In-Line Memory Module, 72-bit data bus 16b-SO-DIMM: Small Outline Unbuffered Dual In-Line Memory Module, 16-bit data bus 32b-SO-DIMM: Small Outline Unbuffered Dual In-Line Memory Module, 32-bit data bus

Hybrid Memory Type Definitions:

NVDIMM: Non-Volatile Dual In-Line Memory Module, Hybrid module with a DRAM-style interface with one or more non-DRAM components for data storage

#### **Examples:**

0x01 = RDIMM, no hybrid memory present

0x91 = RDIMM, NVDIMM hybrid memory present

0x94 = LRDIMM, NVDIMM hybrid memory present

8.1 General Configuration Section: Bytes 0~127 (0x000~0x07F) (Cont'd)

#### 8.1.5 Byte 4 (0x004): SDRAM Density and Banks

This byte, shown in Table 18, defines the total density of the DDR4 SDRAM, in bits, and the number of internal banks and bank groups into which the memory array is divided. For multi-die stacks (DDP, QDP, or 3DS), this represents the capacity of each DRAM die in the stack. These values come from the DDR4 SDRAM data sheet.

Table 18 — Byte 4 (0x004): SDRAM Density and Banks

| Bits 7~6                                                                                             | Bits 5~4                                                          | Bits 3~0                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bank Group Bits                                                                                      | Bank Address Bits <sup>1</sup>                                    | Total SDRAM capacity per die, in megabits                                                                                                                                        |
| Bits [7, 6]:  00 = 0 (no bank groups)  01 = 1 (2 bank groups)  10 = 2 (4 bank groups)  11 = reserved | Bit [5, 4]: 00 = 2 (4 banks) 01 = 3 (8 banks) All others reserved | Bit [3, 2, 1, 0]:  0000 = 256 Mb  0001 = 512 Mb  0010 = 1 Gb  0011 = 2 Gb  0100 = 4 Gb  0101 = 8 Gb  0110 = 16 Gb  0111 = 32 Gb  1000 = 12 Gb  1001 = 24 Gb  All others reserved |

## 8.1.6 Byte 5 (0x005): SDRAM Addressing

This byte, shown in Table 19, describes the row addressing and the column addressing in the SDRAM device. Bits 2~0 encode the number of column address bits, and bits 5~3 encode the number of row address bits. These values come from the DDR4 SDRAM data sheet.

Table 19 — Byte 5 (0x005): SDRAM Addressing

| Bits 7~6                      | Bits 5~3                                                                                                  | Bits 2~0                                                              |
|-------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| Reserved                      | Row Address Bits                                                                                          | Column Address Bits                                                   |
| Reserved; must be coded as 00 | Bit [5, 4, 3]:  000 = 12  001 = 13  010 = 14  011 = 15  100 = 16  101 = 17  110 = 18  All others reserved | Bit [2, 1, 0]: 000 = 9 001 = 10 010 = 11 011 = 12 All others reserved |

#### 8.1.7 Byte 6 (0x006): Primary SDRAM Package Type

This byte, shown in Table 20, describes the type of SDRAM devices on the module. For modules having asymmetrical assembly of multiple SDRAM package types, this byte defines the primary set of SDRAMs; Byte 10 defines the secondary set.

Table 20 — Byte 6 (0x006): Primary SDRAM Package Type

| Bit 7                                                                | Bits 6~4                                                                                                                  | Bits 3~2 | Bit 1~0                                                                                          |
|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------------------------------------|
| Primary SDRAM Package Type                                           | Die Count                                                                                                                 | Reserved | Signal Loading <sup>2</sup>                                                                      |
| 0 = Monolithic DRAM Device<br>1 = Non-Monolithic Device <sup>1</sup> | 000 = Single die<br>001 = 2 die<br>010 = 3 die<br>011 = 4 die<br>100 = 5 die<br>101 = 6 die<br>110 = 7 die<br>111 = 8 die | 00       | 00 = Not specified <sup>3</sup> 01 = Multi load stack 10 = Single load stack (3DS) 11 = Reserved |

NOTE 1 This includes Dual Die, Quad Die, Multi-Die, 3DS, or physically stacked devices - anything that is outside the standard monolithic device.

NOTE 2 Refers to loading on signals at the SDRAM balls. Loading on certain signals (CKE, ODT, etc.) per specification of device stacking as defined in JESD79-4.

NOTE 3 Monolithic DRAM device coded as 00 in bits 1~0.

Terminology: See Table 21.

Table 21 — Package Type Terminology

|                   | 1                 | T                                 |                                         | 71                                   | <i>8</i> /                          |                   |
|-------------------|-------------------|-----------------------------------|-----------------------------------------|--------------------------------------|-------------------------------------|-------------------|
| SDRAM             |                   |                                   |                                         | # Electrica                          | al Loads                            |                   |
| Package<br>Type   | Abbre-<br>viation | Description                       | On data,<br>mask, and<br>strobe signals | On address<br>and command<br>signals | On control<br>signals<br>except CKE | On CKE<br>signals |
| Monolithic        | SDP               | Single die package                | 1                                       | 1                                    | 1                                   | 1                 |
| Multi-load        | DDP               | Dual Die Package                  | 2                                       | 2                                    | 1                                   | 1                 |
| stack             | QDP               | Quad Die Package                  | 4                                       | 4                                    | 1                                   | 2                 |
|                   | 2H 3DS            | Two SDRAM die single load stack   | 1                                       | 1                                    | 1                                   | 1                 |
|                   | 3H 3DS            | Three SDRAM die single load stack | 1                                       | 1                                    | 1                                   | 1                 |
|                   | 4H 3DS            | Four SDRAM die single load stack  | 1                                       | 1                                    | 1                                   | 1                 |
| Single load stack | 5H 3DS            | Five SDRAM die single load stack  | 1                                       | 1                                    | 1                                   | 1                 |
|                   | 6H 3DS            | Six SDRAM die single load stack   | 1                                       | 1                                    | 1                                   | 1                 |
|                   | 7H 3DS            | Seven SDRAM die single load stack | 1                                       | 1                                    | 1                                   | 1                 |
|                   | 8H 3DS            | Eight SDRAM die single load stack | 1                                       | 1                                    | 1                                   | 1                 |

#### 8.1.8 Byte 7 (0x007): SDRAM Optional Features

This byte, shown in Table 22, defines support for certain SDRAM features. This value comes from the DDR4 SDRAM data sheet.

Table 22 — Byte 7 (0x007): SDRAM Optional Features

| Bits 7~6                      | Bits 5~4                                                                                     | Bits 3~0                                                                                                                                                                                                        |
|-------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                      | Maximum Activate<br>Window (tMAW)                                                            | Maximum Activate Count (MAC)                                                                                                                                                                                    |
| Reserved; must be coded as 00 | Bits [5, 4]:<br>00 = 8192 * tREFI<br>01 = 4096 * tREFI<br>10 = 2048 * tREFI<br>11 = Reserved | Bits [3, 2, 1, 0]:  0000 = Untested MAC <sup>1</sup> 0001 = 700 K  0010 = 600 K  0011 = 500 K  0100 = 400 K  0101 = 300 K  0110 = 200 K  0111 = Reserved  1000 = Unlimited MAC <sup>2</sup> All others reserved |

NOTE 1 Untested MAC means the device is not tested for tMAW and/or MAC; no particular value should be assumed.

NOTE 2 Unlimited MAC means there is no restriction to the number of activates to a given row in a refresh period providing DRAM timing requirements such as tRCmin and refresh requirements are not violated.

#### 8.1.9 Byte 8 (0x008): SDRAM Thermal and Refresh Options

This byte, shown in Table 23, describes the module's supported operating temperature ranges and refresh options. These values come from the DDR4 SDRAM data sheet. Please refer to the DDR4 SDRAM data sheet (JESD79-4 or supplier data sheet) for a complete description of these options.

Table 23 — Byte 8 (0x008): SDRAM Thermal and Refresh Options

| Bits 7~0                        |  |  |  |
|---------------------------------|--|--|--|
| Reserved                        |  |  |  |
| Reserved; must be coded as 0x00 |  |  |  |

#### 8.1.10 Byte 9 (0x009): Other SDRAM Optional Features

This byte, shown in Table 24, defines support for certain SDRAM features. This value comes from the DDR4 SDRAM data sheet.

Table 24 — Byte 9 (0x009): Other SDRAM Optional Features

| Bits 7~6                                                                                                  | Bit 5                                                       | Bits 4~0                         |
|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------|
| Post Package Repair (PPR)                                                                                 | Soft PPR                                                    | Reserved                         |
| 00: PPR not supported 01: Post package repair supported, one row per bank group 10: Reserved 11: Reserved | 0 = Soft PPR <b>not</b> supported<br>1 = Soft PPR supported | Reserved; must be coded as 00000 |

NOTE If PPR is supported, Hard PPR is always supported by the device. Optional additional support for Soft PPR is indicated in bit 5.

#### 8.1.11 Byte 10 (0x00A): Secondary SDRAM Package Type

For modules having asymmetrical assembly of multiple SDRAM package types, this byte, shown in Table 25, defines the secondary set of SDRAMs. For modules with symmetrical assembly, this byte must be coded as 0x00.

Table 25 — Byte 10 (0x00A): Secondary SDRAM Package Type

| Bit 7                                                                | Bits 6~4                                                                                                                  | Bits 3~2                                                                                                                                                                                                                                          | Bits 1~0                                                                                     |
|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| SDRAM Package Type                                                   | Die Count                                                                                                                 | DRAM Density Ratio <sup>1</sup>                                                                                                                                                                                                                   | Signal Loading                                                                               |
| 0 = Monolithic DRAM Device<br>1 = Non-Monolithic Device <sup>1</sup> | 000 = Single die<br>001 = 2 die<br>010 = 3 die<br>011 = 4 die<br>100 = 5 die<br>101 = 6 die<br>110 = 7 die<br>111 = 8 die | 00 = Rank 1 and 3 device densities are the same as rank 0 and 2 densities 01 = Rank 1 and 3 are one standard device density smaller than rank 0 and 2 10 = Rank 1 and 3 are two standard device densities smaller than rank 0 and 2 11 = Reserved | 00 = Not specified<br>01 = Multi load stack<br>10 = Single load stack (3DS)<br>11 = Reserved |

NOTE 1 When DRAM Density Ratio (bits 3~2) is non-zero, all SPD settings except timing parameters are specified for the higher density devices in rank 0 (e.g., density, row, column, etc.). SPD timing parameters are specified for the slowest device timings of any rank (e.g., tCK, tAA, tRFC, etc.).

NOTE 2 See Byte 6 for packaging notes.

#### DRAM Density Ratio Settings (Table 26):

Table 26 — DRAM Density Ratio Settings

| SPD Byte 4,<br>Bits 3~0 | Ranks 0, 2<br>Device Density | SPD Byte 10,<br>Bits 3~2 | Ranks 1, 3<br>Device Density | SPD Byte 10,<br>Bits 3~2 | Ranks 1, 3<br>Device Density |
|-------------------------|------------------------------|--------------------------|------------------------------|--------------------------|------------------------------|
| 0000                    | 256 Mb                       | 01                       | Not Defined                  | 10                       | Not Defined                  |
| 0001                    | 512 Mb                       | 01                       | 256 Mb                       | 10                       | Not Defined                  |
| 0010                    | 1 Gb                         | 01                       | 512 Mb                       | 10                       | 256 Mb                       |
| 0011                    | 2 Gb                         | 01                       | 1 Gb                         | 10                       | 512 Mb                       |
| 0100                    | 4 Gb                         | 01                       | 2 Gb                         | 10                       | 1 Gb                         |
| 0101                    | 8 Gb                         | 01                       | 4 Gb                         | 10                       | 2 Gb                         |
| 0110                    | 16 Gb                        | 01                       | 12 Gb                        | 10                       | 8 Gb                         |
| 0111                    | 32 Gb                        | 01                       | 24 Gb                        | 10                       | 16 Gb                        |
| 1000                    | 12 Gb                        | 01                       | 8 Gb                         | 10                       | 4 Gb                         |
| 1001                    | 24 Gb                        | 01                       | 16 Gb                        | 10                       | 12 Gb                        |

#### 8.1.12 Byte 11 (0x00B): Module Nominal Voltage, VDD

This byte, shown in Table 27, describes the Voltage Level for DRAM and other components on the module such as the register or memory buffer if applicable. Note that SPDs or thermal sensor components are on the VDDSPD supply and are not affected by this byte.

'Operable' is defined as the VDD voltage at which module operation is allowed using the performance values programmed in the SPD.

'Endurant' is defined as the VDD voltage at which the module may be powered without adversely affecting the life expectancy or

reliability. Operation is not supported at this voltage.

Table 27 — Byte 11 (0x00B): Module Nominal Voltage, VDD

| Byte 11: Module Nominal Voltage, VDD |                                  |                                  |  |
|--------------------------------------|----------------------------------|----------------------------------|--|
| Reserved                             | DRAM VDD 1.2 V                   |                                  |  |
| Bits 7~2                             | Bit 1 Bit 0                      |                                  |  |
| Reserved;<br>must be coded as 000000 | 0 = not endurant<br>1 = endurant | 0 = not operable<br>1 = operable |  |

#### **Examples:**

A value on bits 1~0 of 11 defines DRAM support of a nominal operable voltage of 1.2 V only.

#### 8.1.13 Byte 12 (0x00C): Module Organization

This byte, shown in Table 28, describes the organization of the SDRAM module. Bits 2~0 encode the device width of the SDRAM devices. Bits 5~3 encode the number of package ranks on the module.

Table 28 — Byte 12 (0x00C): Module Organization

| Bit 7                           | Bit 6                               | Bits 5~3                                                                                                                                                                                              | Bits 2~0                                                                                 |
|---------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| Reserved                        | Rank Mix                            | Number of Package Ranks per<br>DIMM                                                                                                                                                                   | SDRAM Device Width                                                                       |
| Reserved; must<br>be coded as 0 | 0 = Symmetrical<br>1 = Asymmetrical | Bit [5, 4, 3]:  000 = 1 Package Rank  001 = 2 Package Ranks  010 = 3 Package Ranks  011 = 4 Package Ranks  100 = 5 Package Ranks  101 = 6 Package Ranks  110 = 7 Package Ranks  111 = 8 Package Ranks | Bit [2, 1, 0]: 000 = 4 bits 001 = 8 bits 010 = 16 bits 011 = 32 bits All others reserved |

<sup>&</sup>quot;Package ranks per DIMM" refers to the collections of devices on the module sharing common chip select signals (across the data width of the DIMM), either from the edge connector for unbuffered modules or from the outputs of a registering clock driver for RDIMMs and LRDIMMs.

#### 8.1.13.1 Symmetrical Configurations

Byte 12 Bit 6 = 0 defines a memory module as being "symmetrical" where all DRAM devices on the module are the same type as described in Byte 6.

Symmetrical configurations are shown in Figure 1 and Table 29.

<sup>&</sup>quot;Logical rank" refers the individually addressable die in a 3DS stack and has no meaning for monolithic or multi-load stacked SDRAMs, however, for the purposes of calculating the capacity of the module, one should treat monolithic and multi-load stack SDRAMs as having one logical rank per package rank.



Figure 1 — Module Organization: Symmetrical Configurations

**Table 29** — Rank Matrix for Symmetrical Modules (Byte 12 Bit 6 = 0)

| SDRAM Package<br>Type(s) (Byte 6) | # Package Ranks<br>per DIMM | # Logical Ranks<br>per Package Rank<br>(for calculation only) | # Logical Ranks<br>per DIMM |
|-----------------------------------|-----------------------------|---------------------------------------------------------------|-----------------------------|
|                                   | 1                           |                                                               | 1                           |
| SDP                               | 2                           | 1                                                             | 2                           |
| SDF                               | 3                           | '                                                             | 3                           |
|                                   | 4                           |                                                               | 4                           |
| DDD                               | 2                           | 4                                                             | 2                           |
| DDP                               | DDP 1                       | '                                                             | 4                           |
| 2H 3DS                            | 1                           | 2                                                             | 2                           |
| 20 303                            | 2                           |                                                               | 4                           |
| 311 3DC                           | 1                           | 3                                                             | 3                           |
| 3H 3DS                            | 2                           |                                                               | 6                           |
| 4H 3DS                            | 1                           | 4                                                             | 4                           |
| 4H 3D3                            | 2                           | 4                                                             | 8                           |
| 5H 3DS                            | 1                           | 5                                                             | 5                           |
| 30 303                            | 2                           | 5                                                             | 10                          |
| en spe                            | 1                           | 6                                                             | 6                           |
| บท งบง                            | 6H 3DS 2                    |                                                               | 12                          |

|                                   | •                           |                                                                 | , ( )                       |
|-----------------------------------|-----------------------------|-----------------------------------------------------------------|-----------------------------|
| SDRAM Package<br>Type(s) (Byte 6) | # Package Ranks<br>per DIMM | # Logical Ranks<br>per Package Rank<br>(for calculation only)   | # Logical Ranks<br>per DIMM |
| 7H 3DS                            | 1                           | 7                                                               | 7                           |
| 711 303                           | 2                           |                                                                 | 14                          |
| 8H 3DS                            | 1                           | 8                                                               | 8                           |
| 9H 3D3                            | 2                           | 0                                                               | 16                          |
| Logical Ranks                     |                             | per DIMM * # Logical Ranks pe<br>all symmetrical configurations | r Package Rank              |

Table 29 — Rank Matrix for Symmetrical Modules (Byte 12 Bit 6 = 0) (Cont'd)

#### 8.1.13.2 Asymmetrical Configurations

Byte 12 Bit 6 = 1 describes support for modules having a asymmetrical DRAM capacities, for example a 3 package rank module comprised of a combination of SDP and DDP devices, or 3DS-based designs having different numbers of logical ranks in each package rank. When Byte 12 Bit 6 = 1, Byte 6 indicates the package type for the first collection of devices on the module and Byte 10 indicates the package type for the second collection of devices on the module.

Asymmetrical configurations are shown in Figure 2 and Table 30.



Figure 2 — Module Organization: Asymmetrical Configurations

| Type(s) ( | First SDRAM Package<br>Type(s) (Byte 6) and Chip<br>Select Alignment                                     |             | Second SDRAM Package<br>Type(s) (Byte 10) and Chip Select<br>Alignment |    | # Logical Ranks<br>per DIMM |
|-----------|----------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------|----|-----------------------------|
|           |                                                                                                          | Non-3DS Asy | ymmetrical Configuratio                                                | ns |                             |
| SDP       | CS0_n                                                                                                    | DDP         | CS1_n, CS3_n                                                           | 3  | 3                           |
| DDP       | CS0_n, CS2_n                                                                                             | SDP         | CS1_n                                                                  | 3  | 3                           |
|           | 3DS Asymmetrical Configurations                                                                          |             |                                                                        |    |                             |
| 2H 3DS    | CS0_n                                                                                                    | 3H 3DS      | CS1_n                                                                  | 2  | 5                           |
| 2H 3DS    | CS0_n                                                                                                    | 4H 3DS      | CS1_n                                                                  | 2  | 6                           |
|           |                                                                                                          |             |                                                                        |    |                             |
| 7H 3DS    | CS0_n                                                                                                    | 8H 3DS      | CS1_n                                                                  | 2  | 15                          |
| Logical R | Logical Ranks per DIMM = # Logical Ranks in Primary SDRAM type + # Logical Ranks in Secondary SDRAM type |             |                                                                        |    |                             |

Table 30 — Rank Mix for Asymmetrical Modules (Byte 12 Bit 6 = 1)

Examples: see Table 31

Table 31 — Module Configuration Examples

| Byte 12, Bit 6 | Byte 6  | Byte 10   | Byte 12,<br>Bits 5~3, 2~0 | Logical<br>Ranks per | Module Configuration                |
|----------------|---------|-----------|---------------------------|----------------------|-------------------------------------|
| Symmetry       | Primary | Secondary | Ranks, Width              | DIMM                 |                                     |
| 0 = Sym.       | 0x00    | 0x00      | 000, 001                  | 1                    | 1 Package Rank x8, Monolithic       |
| 0 = Sym.       | 0x00    | 0x00      | 001, 001                  | 2                    | 2 Package Ranks x8, Monolithic      |
| 0 = Sym.       | 0x91    | 0x00      | 001, 000                  | 2                    | 2 Package Ranks x4, DDP             |
| 0 = Sym.       | 0xB2    | 0x00      | 000, 000                  | 4                    | 1 Package Rank x4, 4H 3DS           |
| 0 = Sym.       | 0xB2    | 0x00      | 001, 000                  | 8                    | 2 Package Ranks x4, 4H 3DS          |
| 1 = Asym.      | 0x00    | 0x91      | 010, 000                  | 3                    | 3 Package Ranks x4, SDP + DDP       |
| 1 = Asym.      | 0xF2    | 0xE2      | 001, 000                  | 15                   | 2 Package Ranks x4, 8H 3DS + 7H 3DS |

#### 8.1.14 Byte 13 (0x00D): Module Memory Bus Width

This byte, shown in Table 32, describes the width of the SDRAM memory bus on the module. Bits 2~0 encode the primary bus width. Bits 4~3 encode the bus extensions such as parity or ECC.

Table 32 — Byte 13 (0x00D): Module Memory Bus Width

| Bits 7~5                       | Bits 4~3                                                                 | Bits 2~0                                                                                  |
|--------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| Reserved                       | Bus width extension, in bits                                             | Primary bus width, in bits                                                                |
| Reserved; must be coded as 000 | Bit [4, 3]: 000 = 0 bits (no extension) 001 = 8 bits All others reserved | Bit [2, 1, 0]: 000 = 8 bits 001 = 16 bits 010 = 32 bits 011 = 64 bits All others reserved |

#### **Examples:**

- 64 bit primary bus, no parity or ECC (64 bits total width): xxx 000 011
- 64 bit primary bus, with 8 bit ECC (72 bits total width): xxx 001 011

#### Release 29

#### 8.1.14.1 Calculating Module DRAM Capacity

The total memory capacity of the DRAM on the module may be calculated from SPD values. For example, to calculate the total capacity, in megabytes or gigabytes, of a typical module:

Total = SDRAM Capacity ÷ 8 \* Primary Bus Width ÷ SDRAM Width \* Logical Ranks per DIMM

#### where:

- SDRAM Capacity = SPD byte 4 bits 3~0
- Primary Bus Width = SPD byte 13 bits  $2\sim0$
- SDRAM Width = SPD byte 12 bits 2~0
- Logical Ranks per DIMM =

for SDP, DDP, QDP: = SPD byte 12 bits 
$$5\sim3$$

for 3DS: = SPD byte 12 bits  $5\sim3$  times SPD byte 6 bits  $6\sim4$ 

#### **Examples:**

Two package ranks per DIMM using monolithic SDRAMs, 2 Gb per die, with x4 organization on a module with a 64 bit primary bus:

• Total =  $2 \text{ Gb} \div 8 * 64 \div 4 * 2 * 1 = 8 \text{ GB}$ 

Two package ranks per DIMM using DDP SDRAMs, 4 Gb per die, with x4 organization on a module with a 64 bit primary bus:

• Total =  $4 \text{ Gb} \div 8 * 64 \div 4 * 2 = 16 \text{ GB}$ 

Two package ranks per DIMM using 4H 3DS SDRAMs, 2 Gb per die, having a x8 organization on a module with a 64 bit primary

• Total =  $2 \text{ Gb} \div 8 * 64 \div 8 * 2 * 4 = 16 \text{ GB}$ 

Commonly, parity or ECC are not counted in total module capacity, though they can also be included by adding the bus width extension in SPD byte 13 bits  $4\sim3$  to the primary bus width in the previous examples.

#### 8.1.15 Byte 14 (0x00E): Module Thermal Sensor

This byte, shown in Table 33, describes the module's supported thermal options.

Table 33 — Byte 14 (0x00E): Module Thermal Sensor

| Bit 7                                                                                                     | Bits 6~0                             |  |  |
|-----------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|
| Thermal Sensor <sup>1</sup>                                                                               | Reserved                             |  |  |
| 0 = Thermal sensor not incorporated onto this assembly 1 = Thermal sensor incorporated onto this assembly | 0 = Undefined<br>All others reserved |  |  |
| NOTE 1 Thermal sensor compliant with TSE2004av specifications.                                            |                                      |  |  |

#### 8.1.16 Byte 15 (0x00F): Extended Module Type

This byte, shown in Table 34, extends the module type field of byte 3. Used when byte 3 bits  $3\sim0=0000$ .

Table 34 — Byte 15 (0x00F): Extended Module Type

| Bit 7~4                         | Bits 3~0                                                                                         |
|---------------------------------|--------------------------------------------------------------------------------------------------|
| Reserved                        | Extended Base Module Type                                                                        |
| Reserved; must be coded as 0000 | Bits [3, 2, 1, 0]: 0000 = Reserved; must be coded as 0000 1111 = Reserved; must be coded as 0000 |

#### 8.1.17 Byte 16 (0x010):

Reserved, must be coded as 0x00

#### 8.1.18 Byte 17 (0x011): Timebases

This byte, shown in Table 35, defines a value in picoseconds that represents the fundamental timebase for fine grain and medium grain timing calculations. These values are used as a multiplier for formulating subsequent timing parameters.

**Table 35** — Byte 17 (0x011): Timebases

| Bits 7~4                        | Bits 3~2                                           | Bits 1~0                                         |  |  |
|---------------------------------|----------------------------------------------------|--------------------------------------------------|--|--|
| Reserved                        | Medium Timebase (MTB)                              | Fine Timebase (FTB)                              |  |  |
| Reserved; must be coded as 0000 | Bits [3, 2]:<br>00 = 125 ps<br>All others reserved | Bits [0, 1]:<br>00 = 1 ps<br>All others reserved |  |  |

#### 8.1.18.1 Relating the MTB and FTB

When a timing value tXX cannot be expressed by an integer number of MTB units, the SPD must be encoded using both the MTB and FTB. The Fine Offsets are encoded using a two's complement value which, when multiplied by the FTB yields a positive or negative correction factor. Typically, for safety and for legacy compatibility, the MTB portion is rounded UP and the FTB correction is a negative value. The general algorithm for programming SPD values is:

```
Temp val = tXX / MTB
                                                    // Calculate as real number
Remainder = Temp val modulo 1
                                                    // Determine if integer # MTBs
Fine Correction = 1 - Remainder
                                                    // If needed, what correction
if (Remainder == 0) then
                                                    // Integer # MTBs?
        tXX(MTB) = Temp val
                                                    // Convert to integer
        tXX(FTB) = 0
                                                    // No correction needed
else
                                                    // Needs correction
        tXX(MTB) = ceiling (Temp_val)
                                                    // Round up for safety in legacy systems
        tXX(FTB) = Fine_Correction * MTB / FTB
                                                    // Correction is negative offset
endif
```

To recalculate the value of tXX from the SPD values, a general formula BIOSes may use is:

```
tXX = tXX(MTB) * MTB + tXX(FTB) * FTB
```

#### Example (see Table 36):

Table 36 — t<sub>CKAVG</sub>min SPD Calculations Using MTB and FTB

| Speed Bin                                                | t <sub>CKAVG</sub> min Value<br>Decimal | SPD byte 18<br>Decimal<br>(Hexadecimal) | SPD byte 125<br>Decimal<br>(Hexadecimal) |  |  |  |
|----------------------------------------------------------|-----------------------------------------|-----------------------------------------|------------------------------------------|--|--|--|
| DDR4-1866                                                | 1.071 ns                                | 9<br>(0x09)                             | -54<br>(0xCA)                            |  |  |  |
|                                                          | =                                       | (9 * 0.125) + (-54 * 0.001)             |                                          |  |  |  |
| NOTE Examples assume MTB of 0.125 ns and FTB of 0.001 ns |                                         |                                         |                                          |  |  |  |

Timing parameters using both MTB and FTB are shown in Table 37:

Table 37 — Timing parameters using both MTB and FTB

| Parameter              | MTB Byte(s)           | FTB Byte    |
|------------------------|-----------------------|-------------|
| t <sub>CKAVG</sub> min | 18 (0x012)            | 125 (0x07D) |
| t <sub>CKAVG</sub> max | 19 (0x013)            | 124 (0x07C) |
| t <sub>AA</sub> min    | 24 (0x018)            | 123 (0x07B) |
| t <sub>RCD</sub> min   | 25 (0x019)            | 122 (0x07A) |
| t <sub>RP</sub> min    | 26 (0x01A)            | 121 (0x079) |
| t <sub>RC</sub> min    | 27, 29 (0x01B, 0x01D) | 120 (0x078) |
| t <sub>RRD_S</sub> min | 39 (0x027)            | 119 (0x077) |
| t <sub>RRD_L</sub> min | 40 (0x028)            | 118 (0x076) |

The encoding of two's complement fine timebase offsets are shown in Table 38:

Table 38 — Encoding of Two's Complement Fine Timebase Offsets

| (     | Coding   | Value | Value | FTB Timebase |
|-------|----------|-------|-------|--------------|
| Bit 7 | Bits 6~0 | (Dec) | (Hex) | 1 ps         |
| 0     | 1111111  | +127  | 7F    | +127 ps      |
| 0     | 1111110  | +126  | 7E    | +126 ps      |
|       |          |       |       |              |
| 0     | 0000001  | +1    | 01    | +1 ps        |
| 0     | 0000000  | 0     | 00    | 0            |
| 1     | 1111111  | -1    | FF    | -1 ps        |
| 1     | 1111110  | -2    | FE    | -2 ps        |
|       |          |       |       |              |
| 1     | 0000000  | -128  | 80    | -128 ps      |

#### 8.1.18.2 Rounding Algorithms

Software algorithms for calculation of timing parameters are subject to rounding errors from many sources. For example, a system may use a memory clock with a nominal frequency of 933.33... MHz, or a clock period of 1.0714... ns. Similarly, a system with a memory clock frequency of 1066.66... MHz yields mathematically a clock period of 0.9375... ns. In most cases, it is impossible to express all digits after the decimal point exactly, and rounding must be done because the SPD establishes a minimum granularity for timing parameters of 1 ps.

Rules for rounding must be defined to allow optimization of memory module performance without violating device parameters. In some cases, rounding errors cause an unnecessary clock of delay, affecting system performance. These rounding algorithms rely on results that are within correction factors on device testing and specification to avoid losing performance due to rounding errors.

These rules are:

- Clock periods such as t<sub>CKAVG</sub>min are defined to 1 ps of accuracy; for example, 0.9375... ns is defined as 937 ps and 1.0714... ns is defined as 1071 ps.
- Using real math, parameters like t<sub>AA</sub>min, t<sub>RCD</sub>min, etc. which are programmed in systems in numbers of clocks (nCK) but expressed in the SPD in units of time (in ns) are divided by the clock period (in ns) yielding a ratio of clock units (nCK), a correction factor of 2.5% is subtracted, then the result is set to the next higher integer number of clocks:

nCK = ceiling 
$$\frac{\text{parameter\_in\_ns}}{\text{application\_t_{CK\_in\_ns}}} - 0.025$$

• Alternatively, programmers may prefer to use integer math instead of real math by expressing timing in ps, scaling the desired parameter value by 1000, dividing by the application clock period, adding an inverse correction factor of 97.4%, dividing the result by 1000, then truncating down to the next lower integer value:

nCK = truncate 
$$\frac{\left(\frac{\text{parameter\_in\_ps x 1000}}{\text{application\_t_{CK\_in\_ps}}}\right) + 974}{1000}$$

• Either algorithm should yield identical results. In case of any conflict between the two methodologies, the integer method shall prevail.

#### **Examples**

Example 1, using REAL math to convert  $t_{AA}$ min from ns to nCK (see Table 39):

Table 39 — Example 1, using REAL math to convert t<sub>RCD</sub>min from ns to nCK

| DD                   | DDR4-2666W Device Operating at Standard Application Data Rates (Full & Downbinned)  Timing Parameter: t <sub>AA</sub> min = 15.0 ns |                             |                                                         |                      |                                                   |                                    |  |  |  |  |  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|---------------------------------------------------------|----------------------|---------------------------------------------------|------------------------------------|--|--|--|--|--|
| Application<br>Speed | Device t <sub>AA</sub>                                                                                                              | Application t <sub>CK</sub> | Device t <sub>AA</sub> ÷<br>Application t <sub>CK</sub> | 2.5% Cor-<br>rection | t <sub>AA</sub> / t <sub>CK</sub> —<br>Correction | Ceiling<br>Result<br>nCK (integer) |  |  |  |  |  |
| Grade                | ns                                                                                                                                  | ns                          | ratio (real)                                            | (real)               | ratio (real)                                      |                                    |  |  |  |  |  |
| 2666                 | 15.000                                                                                                                              | 0.750                       | 20.0                                                    | 0.025                | 19.975                                            | 20                                 |  |  |  |  |  |
| 2400                 | 15.000                                                                                                                              | 0.833                       | 18.0072                                                 | 0.025                | 17.9822                                           | 18                                 |  |  |  |  |  |
| 2133                 | 15.000                                                                                                                              | 0.937                       | 16.00854                                                | 0.025                | 15.9835                                           | 16                                 |  |  |  |  |  |
| 1866                 | 15.000                                                                                                                              | 1.071                       | 14.0056                                                 | 0.025                | 13.9806                                           | 14                                 |  |  |  |  |  |

Table 39 — Example 1, using REAL math to convert t<sub>RCD</sub>min from ns to nCK (Cont'd)

| DDR4-2666W Device Operating at Standard Application Data Rates (Full & Downbinned) Timing Parameter: t <sub>AA</sub> min = 15.0 ns |                        |                             |                                                         |                      |                                                   |                   |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------|---------------------------------------------------------|----------------------|---------------------------------------------------|-------------------|--|--|--|
| Application<br>Speed                                                                                                               | Device t <sub>AA</sub> | Application t <sub>CK</sub> | Device t <sub>AA</sub> ÷<br>Application t <sub>CK</sub> | 2.5% Cor-<br>rection | t <sub>AA</sub> / t <sub>CK</sub> —<br>Correction | Ceiling<br>Result |  |  |  |
| Grade                                                                                                                              | ns                     | ns                          | ratio (real)                                            | (real)               | ratio (real)                                      | nCK (integer)     |  |  |  |
| 1600                                                                                                                               | 15.000                 | 1.250                       | 12.0                                                    | 0.025                | 11.975                                            | 12                |  |  |  |

NOTE Roundup values for bins 2400, 2133, and 1866 would have lost one clock of performance without the application of the rounding algorithm. For example, a DDR4-2666W device running at DDR4-2400 data rates would have been required to set  $t_{AA}$  to 19 clocks without correction, but with correction  $t_{AA}$  may be safely programmed to 18 clocks.

Example 2, using INT math to convert t<sub>AA</sub>min from ns to nCK (see Table 40):

Table 40 — Example 2, using INT math to convert t<sub>RCD</sub>min from ns to nCK

| DDR4-2666W Device Operating at Standard Application Data Rates (Full & Downbinned) |       |      |            |            |               |  |  |  |  |
|------------------------------------------------------------------------------------|-------|------|------------|------------|---------------|--|--|--|--|
| Timing Parameter: t <sub>AA</sub> min = 15.0 ns (15000 ps)  Application Speed      |       |      |            |            |               |  |  |  |  |
| Grade ps                                                                           |       | ps   | Scaled nCK | Scaled nCK | nCK (integer) |  |  |  |  |
| 2666                                                                               | 15000 | 750  | 20000      | 20974      | 20            |  |  |  |  |
| 2400                                                                               | 15000 | 833  | 18007      | 18981      | 18            |  |  |  |  |
| 2133                                                                               | 15000 | 937  | 16008      | 16982      | 16            |  |  |  |  |
| 1866                                                                               | 15000 | 1071 | 14005      | 14979      | 14            |  |  |  |  |
| 1600                                                                               | 15000 | 1250 | 12000      | 12974      | 12            |  |  |  |  |

#### 8.1.19 Byte 18 (0x012): SDRAM Minimum Cycle Time (t<sub>CKAVG</sub>min)

This byte, shown in Table 41, defines the minimum cycle time for the SDRAM module, in medium timebase (MTB) units. This number applies to all applicable components on the module. This byte applies to SDRAM and support components as well as the overall capability of the DIMM. This value comes from the DDR4 SDRAM and support component data sheets.

Table 41 — Byte 18 (0x012): SDRAM Minimum Cycle Time (t<sub>CKAVG</sub>min)

|                                                   | Bits 7~0  |  |  |  |  |  |
|---------------------------------------------------|-----------|--|--|--|--|--|
| Minimum SDRAM Cycle Time (t <sub>CKAVG</sub> min) |           |  |  |  |  |  |
|                                                   | MTB Units |  |  |  |  |  |
| Values defined from 1 to 255                      |           |  |  |  |  |  |

If  $t_{CKAVG}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{CKAVG}$ min (SPD byte 125) used for correction to get the actual value.

#### Examples (see Table 42):

Table 42 — Examples of SDRAM Minimum Cycle Time

|      | <sub>VG</sub> min<br>B units) | MTB<br>(ns) |     | in Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>CKAVG</sub> min Result<br>(ns) | Use                        |  |  |
|------|-------------------------------|-------------|-----|----------------------------------|-------------|---------------------------------------|----------------------------|--|--|
| 10   | 0x0A                          | 0.125       | 0   | 0                                | 0.001       | 1.25                                  | DDR4-1600 (800 MHz clock)  |  |  |
| 9    | 0x09                          | 0.125       | -54 | 0xCA                             | 0.001       | 1.071                                 | DDR4-1866 (933 MHz clock)  |  |  |
| 8    | 0x08                          | 0.125       | -63 | 0xC1                             | 0.001       | 0.937                                 | DDR4-2133 (1067 MHz clock) |  |  |
| 7    | 0x07                          | 0.125       | -42 | 0xD6                             | 0.001       | 0.833                                 | DDR4-2400 (1200 MHz clock) |  |  |
| 6    | 0x06                          | 0.125       | 0   | 0                                | 0.001       | 0.750                                 | DDR4-2666 (1333 MHz clock) |  |  |
| 6    | 0x06                          | 0.125       | -68 | 0xBC                             | 0.001       | 0.682                                 | DDR4-2933 (1466 MHz clock) |  |  |
| 5    | 0x05                          | 0.125       | 0   | 0                                | 0.001       | 0.625                                 | DDR4-3200 (1600 MHz clock) |  |  |
| NOTE | NOTE 1 1: See SPD byte 125.   |             |     |                                  |             |                                       |                            |  |  |

## 8.1.20 Byte 19 (0x013): SDRAM Maximum Cycle Time (t<sub>CKAVG</sub>max)

This word defines the maximum cycle time for the SDRAM module, in medium timebase (MTB) units. This number applies to all applicable components on the module. This byte, shown in Table 43, applies to SDRAM and support components as well as the overall capability of the DIMM. This value comes from the DDR4 SDRAM and support component data sheets.

Table 43 — Byte 19 (0x013): SDRAM Maximum Cycle Time (t<sub>CKAVG</sub>max)

|                              | Bits 7~0                                          |  |  |  |  |  |  |
|------------------------------|---------------------------------------------------|--|--|--|--|--|--|
|                              | Minimum SDRAM Cycle Time (t <sub>CKAVG</sub> max) |  |  |  |  |  |  |
|                              | MTB Units                                         |  |  |  |  |  |  |
| Values defined from 1 to 255 | <u> </u>                                          |  |  |  |  |  |  |

If  $t_{CKAVG}$ max cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{CKAVG}$ max (SPD byte 124) used for correction to get the actual value.

Examples: See Table 44.

Table 44 — Examples of SDRAM Maximum Cycle Time

|      | <sub>VG</sub> max<br>3 units) | MTB<br>(ns) | t <sub>CKAVG</sub> m<br>(FTB t | ax Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>CKAVG</sub> max<br>Result | Use                            |  |  |
|------|-------------------------------|-------------|--------------------------------|----------------------------------|-------------|----------------------------------|--------------------------------|--|--|
|      | ,                             |             | (                              |                                  |             | (ns)                             |                                |  |  |
| 13   | 0x0D                          | 0.125       | -25                            | 0xE7                             | 0.001       | 1.600                            | DDR4-1600 (800 MHz clock)      |  |  |
| 13   | 0x0D                          | 0.125       | -25                            | 0xE7                             | 0.001       | 1.600                            | DDR4-1866 (933 MHz clock)      |  |  |
| 13   | 0x0D                          | 0.125       | -25                            | 0xE7                             | 0.001       | 1.600                            | DDR4-2133 (1067 MHz clock)     |  |  |
| 13   | 0x0D                          | 0.125       | -25                            | 0xE7                             | 0.001       | 1.600                            | DDR4-2400 (1200 MHz clock)     |  |  |
| 13   | 0x0D                          | 0.125       | -25                            | 0xE7                             | 0.001       | 1.600                            | DDR4-2666 (1333 MHz clock)     |  |  |
| 13   | 0x0D                          | 0.125       | -25                            | 0xE7                             | 0.001       | 1.600                            | DDR4-2933 (1466 MHz clock)     |  |  |
| 13   | 0x0D                          | 0.125       | -25                            | 0xE7                             | 0.001       | 1.600                            | DDR4-3200 (1600 MHz clock)     |  |  |
| 12   | 0x0C                          | 0.125       | 0                              | 0                                | 0.001       | 1.500                            | DDR4-1600 3DS (800 MHz clock)  |  |  |
| 12   | 0x0C                          | 0.125       | 0                              | 0                                | 0.001       | 1.500                            | DDR4-1866 3DS (933 MHz clock)  |  |  |
| 12   | 0x0C                          | 0.125       | 0                              | 0                                | 0.001       | 1.500                            | DDR4-2133 3DS (1067 MHz clock) |  |  |
| 12   | 0x0C                          | 0.125       | 0                              | 0                                | 0.001       | 1.500                            | DDR4-2400 3DS (1200 MHz clock) |  |  |
| 12   | 0x0C                          | 0.125       | 0                              | 0                                | 0.001       | 1.500                            | DDR4-2666 3DS (1333 MHz clock) |  |  |
| 12   | 0x0C                          | 0.125       | 0                              | 0                                | 0.001       | 1.500                            | DDR4-2933 3DS (1466 MHz clock) |  |  |
| 12   | 0x0C                          | 0.125       | 0                              | 0                                | 0.001       | 1.500                            | DDR4-3200 3DS (1600 MHz clock) |  |  |
| NOTE | NOTE 1 1: See SPD byte 124.   |             |                                |                                  |             |                                  |                                |  |  |

8.1 General Configuration Section: Bytes 0~127 (0x000~0x07F) (Cont'd)

8.1.21 Byte 20 (0x014): CAS Latencies Supported, First Byte

Byte 21 (0x015): CAS Latencies Supported, Second Byte

Byte 22 (0x016): CAS Latencies Supported, Third Byte

Byte 23 (0x017): CAS Latencies Supported, Fourth Byte

These bytes, shown in Tables 45 and 46, define which CAS Latency (CL) values are supported with one bit per possible CAS Latency. A 1 in a bit position means that CL is supported, a 0 in that bit position means it is not supported. Bit 7 of byte 23 selects the range of CL values, 7~36 or 23~52. Byte 23 bit 6 is reserved for future use and must be coded as 0. These values come from the DDR4 SDRAM data sheet, JESD79-4.

CAS Latency Mask may cover either non-DBI mode or both DBI and non-DBI modes of operation; this is vendor specific.

|         |                  |         | ,       |         | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | • • • • • • • • • • • • • • • • • • • • |         |         |
|---------|------------------|---------|---------|---------|-----------------------------------------|-----------------------------------------|---------|---------|
| Puto 20 | Bit 7            | Bit 6   | Bit 5   | Bit 4   | Bit 3                                   | Bit 2                                   | Bit 1   | Bit 0   |
| Byte 20 | CL = 14          | CL = 13 | CL = 12 | CL = 11 | CL = 10                                 | CL = 9                                  | CL = 8  | CL = 7  |
| Buto 24 | Bit 7            | Bit 6   | Bit 5   | Bit 4   | Bit 3                                   | Bit 2                                   | Bit 1   | Bit 0   |
| Byte 21 | CL = 22          | CL = 21 | CL = 20 | CL = 19 | CL = 18                                 | CL = 17                                 | CL = 16 | CL = 15 |
| Puto 22 | Bit 7            | Bit 6   | Bit 5   | Bit 4   | Bit 3                                   | Bit 2                                   | Bit 1   | Bit 0   |
| Byte 22 | CL = 30          | CL = 29 | CL = 28 | CL = 27 | CL = 26                                 | CL = 25                                 | CL = 24 | CL = 23 |
| Byte 23 | Bit 7            | Bit 6   | Bit 5   | Bit 4   | Bit 3                                   | Bit 2                                   | Bit 1   | Bit 0   |
|         | 0 = Low CL range | Rsvd    | CL = 36 | CL = 35 | CL = 34                                 | CL = 33                                 | CL = 32 | CL = 31 |

Table 45 — CAS Latencies, Low Range (Byte 23 Bit 7 = 0)

NOTE 1 Byte 23 bit 7 selects the possible CAS Latency range.

NOTE 2 Byte 23 bit 6 is reserved and must be coded as 0.

NOTE 3 For each other bit position, 0 means this CAS Latency is not supported, 1 means this CAS Latency is supported.

| Puto 20 | Bit 7             | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------|-------------------|---------|---------|---------|---------|---------|---------|---------|
| Byte 20 | CL = 30           | CL = 29 | CL = 28 | CL = 27 | CL = 26 | CL = 25 | CL = 24 | CL = 23 |
| Puto 24 | Bit 7             | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
| Byte 21 | CL = 38           | CL = 37 | CL = 36 | CL = 35 | CL = 34 | CL = 33 | CL = 32 | CL = 31 |
| Puto 22 | Bit 7             | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
| Byte 22 | CL = 46           | CL = 45 | CL = 44 | CL = 43 | CL = 42 | CL = 41 | CL = 40 | CL = 39 |
| Puto 22 | Bit 7             | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
| Byte 23 | 1 = High CL range | Rsvd    | CL = 52 | CL = 51 | CL = 50 | CL = 49 | CL = 48 | CL = 47 |

Table 46 — CAS Latencies, High Range (Byte 23 Bit 7 = 1)

#### Example 1:

Byte 23 bit 7 = 0 (Low CL Range)

Byte  $20 = 0xB4 (= 1011 \ 0100)$  -- first byte

Byte 21 = 0x05 (= 0000 0101) -- second byte

Byte 22 = 0x00 (= 0000 0000) -- third byte

Byte 23 = 0x00 (= 0000 0000) -- fourth byte

| <b>CAS Latencies</b> | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  |
|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| CL Mask              | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 1  | 1  | 0  | 1  | 0  | 0  |
| CAS Latencies        | R  | X  | 36 | 35 | 34 | 33 | 32 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 |

NOTE 1 Byte 23 bit 7 selects the possible CAS Latency range.

NOTE 2 Byte 23 bit 6 is reserved and must be coded as 0.

NOTE 3 For each other bit position, 0 means this CAS Latency is not supported, 1 means this CAS Latency is supported.

Results: Actual CAS Latencies supported = 9, 11, 12, 14, 15, 17

#### Example 2:

Byte 23 bit 7 = 1 (High CL Range)

Byte 20 = 0x00 (= 0000 0000) -- first byte

Byte  $21 = 0x78 (= 0111 \ 1000)$  -- second byte

Byte 22 = 0x01 (= 0000 0001) -- third byte

Byte  $23 = 0x80 (= 1000\ 0000)$  -- fourth byte

| <b>CAS Latencies</b> | 38 | 37 | 36 | 35 | 34 | 33 | 32 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 |
|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| CL Mask              | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| CAS Latencies        | R  | Х  | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 |
| CL Mask              | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  |

Results: Actual CAS Latencies supported = 34, 35, 36, 37, 39

# 8.1.22 Byte 24 (0x018): Minimum CAS Latency Time (t<sub>AA</sub>min)

This word, shown in Table 47, defines the minimum CAS Latency in medium timebase (MTB) units. This value comes from the DDR4 SDRAM data sheet.

Table 47 — Byte 24 (0x018): Minimum CAS Latency Time (t<sub>AA</sub>min)



If  $t_{AA}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{AA}$ min (SPD byte 123) used for correction to get the actual value.

**Examples:** See Table 48.

Table 48 — Examples of Minimum CAS Latency Time

| 1 '' | <sub>4</sub> min<br>3 units) | MTB<br>(ns) | t <sub>AA</sub> min Offset<br>(FTB units) <sup>1</sup> |      | FTB<br>(ns) | t <sub>AA</sub> min<br>Result<br>(ns) | Use          | Notes |
|------|------------------------------|-------------|--------------------------------------------------------|------|-------------|---------------------------------------|--------------|-------|
| 100  | 0x64                         | 0.125       | 0                                                      | 0    | 0.001       | 12.50                                 | DDR4-1600J   |       |
| 110  | 0x6E                         | 0.125       | 0                                                      | 0    | 0.001       | 13.75                                 | DDR4-1600K   |       |
| 108  | 0x6C                         | 0.125       | 0                                                      | 0    | 0.001       | 13.50                                 | DDR4-1600K-D | 2     |
| 120  | 0x78                         | 0.125       | 0                                                      | 0    | 0.001       | 15.00                                 | DDR4-1600L   |       |
| 103  | 0x67                         | 0.125       | -26                                                    | 0xE6 | 0.001       | 12.85                                 | DDR4-1866L   |       |
| 112  | 0x70                         | 0.125       | -81                                                    | 0xAF | 0.001       | 13.92                                 | DDR4-1866M   |       |
| 108  | 0x6C                         | 0.125       | 0                                                      | 0    | 0.001       | 13.50                                 | DDR4-1866M-D | 2     |
| 120  | 0x78                         | 0.125       | 0                                                      | 0    | 0.001       | 15.00                                 | DDR4-1866N   |       |
| 106  | 0x6A                         | 0.125       | -120                                                   | 0x88 | 0.001       | 13.13                                 | DDR4-2133N   |       |
| 113  | 0x71                         | 0.125       | -65                                                    | 0xBF | 0.001       | 14.06                                 | DDR4-2133P   |       |
| 108  | 0x6C                         | 0.125       | 0                                                      | 0    | 0.001       | 13.50                                 | DDR4-2133P-D | 2     |
| 120  | 0x78                         | 0.125       | 0                                                      | 0    | 0.001       | 15.00                                 | DDR4-2133R   |       |
| 100  | 0x64                         | 0.125       | 0                                                      | 0    | 0.001       | 12.50                                 | DDR4-2400P   |       |
| 107  | 0x6B                         | 0.125       | -55                                                    | 0xC9 | 0.001       | 13.32                                 | DDR4-2400R   |       |
| 114  | 0x72                         | 0.125       | -90                                                    | 0xA6 | 0.001       | 14.16                                 | DDR4-2400T   |       |

Table 48 — Examples of Minimum CAS Latency Time (Cont'd)

|                  | <sub>(</sub> min<br>3 units) | MTB<br>(ns)          |      | n Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>AA</sub> min<br>Result | Use                                    | Notes |
|------------------|------------------------------|----------------------|------|---------------------------------|-------------|-------------------------------|----------------------------------------|-------|
|                  | -                            |                      | ,    | *                               |             | (ns)                          |                                        |       |
| 110              | 0x6E                         | 0.125                | 0    | 0                               | 0.001       | 13.75                         | DDR4-2400T-D                           | 2     |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-2400U                             |       |
| 102              | 0x66                         | 0.125                | 0    | 0                               | 0.001       | 12.75                         | DDR4-2666T                             |       |
| 108              | 0x6C                         | 0.125                | 0    | 0                               | 0.001       | 13.50                         | DDR4-2666U                             |       |
| 114              | 0x72                         | 0.125                | 0    | 0                               | 0.001       | 14.25                         | DDR4-2666V                             |       |
| 110              | 0x6E                         | 0.125                | 0    | 0                               | 0.001       | 13.75                         | DDR4-2666V-D                           | 2     |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-2666W                             |       |
| 104              | 0x68                         | 0.125                | -40  | 0xD8                            | 0.001       | 12.96                         | DDR4-2933V                             |       |
| 110              | 0x6E                         | 0.125                | -110 | 0x92                            | 0.001       | 13.64                         | DDR4-2933W                             |       |
| 115              | 0x73                         | 0.125                | -55  | 0xC9                            | 0.001       | 14.32                         | DDR4-2933Y                             |       |
| 110              | 0x6E                         | 0.125                | 0    | 0                               | 0.001       | 13.75                         | DDR4-2933Y-D                           | 2     |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-2933AA                            |       |
| 100              | 0x64                         | 0.125                | 0    | 0                               | 0.001       | 12.50                         | DDR4-3200W                             |       |
| 110              | 0x6E                         | 0.125                | 0    | 0                               | 0.001       | 13.75                         | DDR4-3200AA                            |       |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-3200AB                            |       |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-1600J-3DS2B                       |       |
| 130              | 0x82                         | 0.125                | 0    | 0                               | 0.001       | 16.25                         | DDR4-1600K-3DS2B                       |       |
| 140              | 0x8C                         | 0.125                | 0    | 0                               | 0.001       | 17.50                         | DDR4-1600L-3DS2B                       |       |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-1866L-3DS2B                       |       |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-1866L-D-3DS2B                     | 2     |
| 129              | 0x81                         | 0.125                | -55  | 0xC9                            | 0.001       | 16.07                         | DDR4-1866M-3DS2B                       |       |
| 129              | 0x81                         | 0.125                | -55  | 0xC9                            | 0.001       | 16.07                         | DDR4-1866M-D-3DS2B                     | 2     |
| 138              | 0x8A                         | 0.125                | -110 | 0x92                            | 0.001       | 17.14                         | DDR4-1866N-3DS2B                       |       |
| 128              | 0x80                         | 0.125                | -51  | 0xCD                            | 0.001       | 15.95                         | DDR4-2133P-3DS2A                       |       |
| 128              | 0x80                         | 0.125                | -51  | 0xCD                            | 0.001       | 15.95                         | DDR4-2133P-D-3DS2A                     | 2     |
| 136              | 0x88                         | 0.125                | -121 | 0x87                            | 0.001       | 16.88                         | DDR4-2133R-3DS3A                       |       |
| 151              | 0x97                         | 0.125                | -115 | 0x8D                            | 0.001       | 18.76                         | DDR4-2133R-3DS4A                       |       |
| 138              | 0x8A                         | 0.125                | -110 | 0x92                            | 0.001       | 17.14                         | DDR4-2133R-D-3DS4A                     | 2     |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-2400P-3DS3B                       |       |
| 127              | 0x7F                         | 0.125                | -45  | 0xD3                            | 0.001       | 15.83                         | DDR4-2400T-3DS2A                       |       |
| 134              | 0x86                         | 0.125                | -80  | 0xB0                            | 0.001       | 16.67                         | DDR4-2400U-3DS2A                       |       |
| 147              | 0x93                         | 0.125                | -46  | 0xD2                            | 0.001       | 18.33                         | DDR4-2400U-3DS4A                       |       |
| 138              | 0x8A                         | 0.125                | -110 | 0x92                            | 0.001       | 17.14                         | DDR4-2400U-D-3DS4A                     | 2     |
| 120              | 0x78                         | 0.125                | 0    | 0                               | 0.001       | 15.00                         | DDR4-2666T-3DS3A                       | _     |
| 132              | 0x76                         | 0.125                | 0    | 0                               | 0.001       | 16.50                         | DDR4-2666V-3DS3A                       |       |
| 144              | 0x84<br>0x90                 | 0.125                | 0    | 0                               | 0.001       | 18.00                         | DDR4-2666W-3DS4A                       |       |
| 138              | 0x8A                         | 0.125                | -110 | 0x92                            | 0.001       | 17.14                         | DDR4-2666W-D-3DS4A                     | 2     |
| 100              | UNUM                         | 0.125                | -110 | 0.022                           | 0.001       | tbd                           | DDR4-2933tbd-3DStbd                    | _     |
|                  |                              | 0.125                |      |                                 | 0.001       | tbd                           | DDR4-2933tbd-3DStbd                    |       |
|                  |                              | 0.125                |      |                                 | 0.001       | tbd                           | DDR4-2933tbd-3DStbd                    |       |
| 120              | 0v70                         | 0.125                | 0    | 0                               |             | 15.00                         | DDR4-3200W-3DS4A                       |       |
| 120              | 0x78                         |                      |      |                                 | 0.001       | 16.25                         | DDR4-3200AA-3DS4A                      |       |
| 130              | 0x82                         | 0.125                | 0    | 0                               | 0.001       | 17.50                         | DDR4-3200AC-3DS4A                      |       |
| 140              | 0x8C                         | 0.125                | 0    | 0                               | 0.001       | 17.14                         | DDR4-3200AC-3DS4A  DDR4-3200AC-D-3DS4A | 2     |
| 138              | A8x0                         | 0.125                | -110 | 0x92                            | 0.001       | 17.14                         | DDI(4-3200AC-D-3D34A                   |       |
| NOTE 1<br>NOTE 2 |                              | SPD byte 1 to device |      | t for downb                     | in support  | details.                      |                                        |       |

#### 8.1.23 Byte 25 (0x019): Minimum RAS to CAS Delay Time (t<sub>RCD</sub>min)

This word, shown in Table 49, defines the minimum SDRAM RAS to CAS Delay Time in medium timebase (MTB) units. This value comes from the DDR4 SDRAM data sheet.

Table 49 — Byte 25 (0x019): Minimum RAS to CAS Delay Time (t<sub>RCD</sub>min)

Bits 7~0

Byte 25: Minimum SDRAM RAS to CAS Delay Time (t<sub>RCD</sub>min)

MTB Units

Values defined from 1 to 255

If  $t_{RCD}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{RCD}$ min (SPD byte 122) used for correction to get the actual value.

**Examples:** See Table 50.

Table 50 — Examples of Minimum RAS to CAS Delay Time

| t <sub>RC</sub> | <sub>CD</sub> min | МТВ   | t <sub>RCD</sub> mi | n Offset            | FTB   | t <sub>RCD</sub> min |                    |       |
|-----------------|-------------------|-------|---------------------|---------------------|-------|----------------------|--------------------|-------|
| _               | 3 units)          | (ns)  | (FTB                | units) <sup>1</sup> | (ns)  | Result               | Use                | Notes |
| 400             | 004               | 0.405 | ,                   |                     | 0.004 | (ns)<br>12.50        | DDR4-1600J         | +     |
| 100             | 0x64              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-1600K         |       |
| 110             | 0x6E              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-1600K-D       | 2     |
| 108             | 0x6C              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-1600K-D       | 2     |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 12.85                | DDR4-1866L         |       |
| 103             | 0x67              | 0.125 | -26                 | 0xE6                | 0.001 | 13.92                | DDR4-1866M         |       |
| 112             | 0x70              | 0.125 | -81                 | 0xAF                | 0.001 |                      |                    | 2     |
| 108             | 0x6C              | 0.125 | 0                   | 0                   | 0.001 | 13.50                | DDR4-1866M-D       | 2     |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-1866N         |       |
| 106             | 0x6A              | 0.125 | -120                | 0x88                | 0.001 | 13.13                | DDR4-2133N         |       |
| 113             | 0x71              | 0.125 | -65                 | 0xBF                | 0.001 | 14.06                | DDR4-2133P         | _     |
| 108             | 0x6C              | 0.125 | 0                   | 0                   | 0.001 | 13.50                | DDR4-2133P-D       | 2     |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-2133R         |       |
| 100             | 0x64              | 0.125 | 0                   | 0                   | 0.001 | 12.50                | DDR4-2400P         |       |
| 107             | 0x6B              | 0.125 | -55                 | 0xC9                | 0.001 | 13.32                | DDR4-2400R         |       |
| 114             | 0x72              | 0.125 | -90                 | 0xA6                | 0.001 | 14.16                | DDR4-2400T         |       |
| 110             | 0x6E              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-2400T-D       | 2     |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-2400U         |       |
| 102             | 0x66              | 0.125 | 0                   | 0                   | 0.001 | 12.75                | DDR4-2666T         |       |
| 108             | 0x6C              | 0.125 | 0                   | 0                   | 0.001 | 13.50                | DDR4-2666U         |       |
| 114             | 0x72              | 0.125 | 0                   | 0                   | 0.001 | 14.25                | DDR4-2666V         |       |
| 110             | 0x6E              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-2666V-D       | 2     |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-2666W         |       |
| 104             | 0x68              | 0.125 | -40                 | 0xD8                | 0.001 | 12.96                | DDR4-2933V         |       |
| 110             | 0x6E              | 0.125 | -110                | 0x92                | 0.001 | 13.64                | DDR4-2933W         |       |
| 115             | 0x73              | 0.125 | -55                 | 0xC9                | 0.001 | 14.32                | DDR4-2933Y         |       |
| 110             | 0x6E              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-2933Y-D       | 2     |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-2933AA        |       |
| 100             | 0x64              | 0.125 | 0                   | 0                   | 0.001 | 12.50                | DDR4-3200W         |       |
| 110             | 0x6E              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-3200AA        |       |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-3200AB        |       |
| 110             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-1600J-3DS2B   |       |
| 120             | 0x78              | 0.125 | 0                   | 0                   | 0.001 | 15.00                | DDR4-1600K-3DS2B   |       |
| 130             | 0x82              | 0.125 | 0                   | 0                   | 0.001 | 16.25                | DDR4-1600L-3DS2B   |       |
| 112             | 0x70              | 0.125 | -81                 | 0xAF                | 0.001 | 13.92                | DDR4-1866L-3DS2B   |       |
| 110             | 0x6E              | 0.125 | 0                   | 0                   | 0.001 | 13.75                | DDR4-1866L-D-3DS2B | 2     |

|        | _                             |                         | Lam  | <del></del> ,                   |             |                                        |                     |       |
|--------|-------------------------------|-------------------------|------|---------------------------------|-------------|----------------------------------------|---------------------|-------|
|        | <sub>:D</sub> min<br>3 units) | MTB<br>(ns)             |      | n Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>RCD</sub> min<br>Result<br>(ns) | Use                 | Notes |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-1866M-3DS2B    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-1866M-D-3DS2B  | 2     |
| 129    | 0x81                          | 0.125                   | -55  | 0xC9                            | 0.001       | 16.07                                  | DDR4-1866N-3DS2B    |       |
| 113    | 0x71                          | 0.125                   | -65  | 0xBF                            | 0.001       | 14.06                                  | DDR4-2133P-3DS2A    |       |
| 113    | 0x71                          | 0.125                   | -65  | 0xBF                            | 0.001       | 14.06                                  | DDR4-2133P-D-3DS2A  | 2     |
| 113    | 0x71                          | 0.125                   | -65  | 0xBF                            | 0.001       | 14.06                                  | DDR4-2133R-3DS3A    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-2133R-3DS4A    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-2133R-D-3DS4A  | 2     |
| 107    | 0x6B                          | 0.125                   | -45  | 0xD3                            | 0.001       | 13.33                                  | DDR4-2400P-3DS3B    |       |
| 114    | 0x72                          | 0.125                   | -90  | 0xA6                            | 0.001       | 14.16                                  | DDR4-2400T-3DS2A    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-2400U-3DS2A    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-2400U-3DS4A    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-2400U-D-3DS4A  | 2     |
| 102    | 0x66                          | 0.125                   | 0    | 0                               | 0.001       | 12.75                                  | DDR4-2666T-3DS3A    |       |
| 114    | 0x72                          | 0.125                   | 0    | 0                               | 0.001       | 14.25                                  | DDR4-2666V-3DS3A    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-2666W-3DS4A    |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-2666W-D-3DS4A  | 2     |
|        |                               | 0.125                   |      |                                 | 0.001       | tbd                                    | DDR4-2933tbd-3DStbd |       |
|        |                               | 0.125                   |      |                                 | 0.001       | tbd                                    | DDR4-2933tbd-3DStbd |       |
|        |                               | 0.125                   |      |                                 | 0.001       | tbd                                    | DDR4-2933tbd-3DStbd |       |
| 100    | 0x64                          | 0.125                   | 0    | 0                               | 0.001       | 12.50                                  | DDR4-3200W-3DS4A    |       |
| 107    | 0x6B                          | 0.125                   | -105 | 0x97                            | 0.001       | 13.27                                  | DDR4-3200AA-3DS4A   |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-3200AC-3DS4A   |       |
| 120    | 0x78                          | 0.125                   | 0    | 0                               | 0.001       | 15.00                                  | DDR4-3200AC-D-3DS4A | 2     |
| NOTE 1 |                               | D byte 122<br>device da |      | or downbin                      | support de  | tails.                                 |                     |       |

Table 50 — Examples of Minimum RAS to CAS Delay Time (Cont'd)

#### 8.1.24 Byte 26 (0x01A): Minimum Row Precharge Delay Time (t<sub>RP</sub>min)

This word, shown in Table 51, defines the minimum SDRAM Row Precharge Delay Time in medium timebase (MTB) units. This value comes from the DDR4 SDRAM data sheet.

Table 51 — Byte 26 (0x01A): Minimum Row Precharge Delay Time (t<sub>RP</sub>min)

|                              | Bits 7~0                                         |
|------------------------------|--------------------------------------------------|
|                              | Minimum Row Precharge Time (t <sub>RP</sub> min) |
|                              | MTB Units                                        |
| Values defined from 1 to 255 |                                                  |

If  $t_{RP}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{RP}$ min (SPD byte 121) used for correction to get the actual value.

Examples: See Table 52.

Table 52 — Examples of Minimum Row Precharge Delay Time

|     | omin<br>3 units) | MTB<br>(ns) | 1 (1 | n Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>RP</sub> min<br>Result<br>(ns) | Use          | Notes |
|-----|------------------|-------------|------|---------------------------------|-------------|---------------------------------------|--------------|-------|
| 100 | 0x64             | 0.125       | 0    | 0                               | 0.001       | 12.50                                 | DDR4-1600J   |       |
| 110 | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75                                 | DDR4-1600K   |       |
| 108 | 0x6C             | 0.125       | 0    | 0                               | 0.001       | 13.50                                 | DDR4-1600K-D | 2     |

Table 52 — Examples of Minimum Row Precharge Delay Time (Cont'd)

| t min MTD to-min Offcot STD t <sub>RP</sub> min |                  |             |      |                                 |             |        |                     |       |  |  |  |
|-------------------------------------------------|------------------|-------------|------|---------------------------------|-------------|--------|---------------------|-------|--|--|--|
|                                                 | omin<br>3 units) | MTB<br>(ns) |      | n Offset<br>units) <sup>1</sup> | FTB<br>(ns) | Result | Use                 | Notes |  |  |  |
| *                                               |                  | ` ′         |      |                                 | ` '         | (ns)   |                     |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-1600L          |       |  |  |  |
| 103                                             | 0x67             | 0.125       | -26  | 0xE6                            | 0.001       | 12.85  | DDR4-1866L          |       |  |  |  |
| 112                                             | 0x70             | 0.125       | -81  | 0xAF                            | 0.001       | 13.92  | DDR4-1866M          |       |  |  |  |
| 108                                             | 0x6C             | 0.125       | 0    | 0                               | 0.001       | 13.50  | DDR4-1866M-D        | 2     |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-1866N          |       |  |  |  |
| 106                                             | 0x6A             | 0.125       | -120 | 0x88                            | 0.001       | 13.13  | DDR4-2133N          |       |  |  |  |
| 113                                             | 0x71             | 0.125       | -65  | 0xBF                            | 0.001       | 14.06  | DDR4-2133P          |       |  |  |  |
| 108                                             | 0x6C             | 0.125       | 0    | 0                               | 0.001       | 13.50  | DDR4-2133P-D        | 2     |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2133R          |       |  |  |  |
| 100                                             | 0x64             | 0.125       | 0    | 0                               | 0.001       | 12.50  | DDR4-2400P          |       |  |  |  |
| 107                                             | 0x6B             | 0.125       | -55  | 0xC9                            | 0.001       | 13.32  | DDR4-2400R          |       |  |  |  |
| 114                                             | 0x72             | 0.125       | -90  | 0xA6                            | 0.001       | 14.16  | DDR4-2400T          |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75  | DDR4-2400T-D        | 2     |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2400U          |       |  |  |  |
| 102                                             | 0x66             | 0.125       | 0    | 0                               | 0.001       | 12.75  | DDR4-2666T          |       |  |  |  |
| 108                                             | 0x6C             | 0.125       | 0    | 0                               | 0.001       | 13.50  | DDR4-2666U          |       |  |  |  |
| 114                                             | 0x72             | 0.125       | 0    | 0                               | 0.001       | 14.25  | DDR4-2666V          |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75  | DDR4-2666V-D        | 2     |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2666W          |       |  |  |  |
| 104                                             | 0x68             | 0.125       | -40  | 0xD8                            | 0.001       | 12.96  | DDR4-2933V          |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | -110 | 0x92                            | 0.001       | 13.64  | DDR4-2933W          |       |  |  |  |
| 115                                             | 0x73             | 0.125       | -55  | 0xC9                            | 0.001       | 14.32  | DDR4-2933Y          |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75  | DDR4-2933Y-D        | 2     |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2933AA         |       |  |  |  |
| 100                                             | 0x64             | 0.125       | 0    | 0                               | 0.001       | 12.50  | DDR4-3200W          |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75  | DDR4-3200AA         |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-3200AB         |       |  |  |  |
| 100                                             | 0x64             | 0.125       | 0    | 0                               | 0.001       | 12.50  | DDR4-1600J-3DS2B    |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75  | DDR4-1600K-3DS2B    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-1600L-3DS2B    |       |  |  |  |
| 103                                             | 0x67             | 0.125       | -26  | 0xE6                            | 0.001       | 12.85  | DDR4-1866L-3DS2B    |       |  |  |  |
| 103                                             | 0x67             | 0.125       | -26  | 0xE6                            | 0.001       | 12.85  | DDR4-1866L-D-3DS2B  | 2     |  |  |  |
| 112                                             | 0x70             | 0.125       | -81  | 0xAF                            | 0.001       | 13.92  | DDR4-1866M-3DS2B    |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75  | DDR4-1866M-D-3DS2B  | 2     |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-1866N-3DS2B    |       |  |  |  |
| 113                                             | 0x71             | 0.125       | -65  | 0xBF                            | 0.001       | 14.06  | DDR4-2133P-3DS2A    |       |  |  |  |
| 110                                             | 0x6E             | 0.125       | 0    | 0                               | 0.001       | 13.75  | DDR4-2133P-D-3DS2A  | 2     |  |  |  |
| 113                                             | 0x71             | 0.125       | -65  | 0xBF                            | 0.001       | 14.06  | DDR4-2133R-3DS3A    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2133R-3DS4A    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2133R-D-3DS4A  | 2     |  |  |  |
| 100                                             | 0x64             | 0.125       | 0    | 0                               | 0.001       | 12.50  | DDR4-2400P-3DS3B    |       |  |  |  |
| 114                                             | 0x72             | 0.125       | -90  | 0xA6                            | 0.001       | 14.16  | DDR4-2400T-3DS2A    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2400U-3DS2A    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2400U-3DS4A    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2400U-D-3DS4A  | 2     |  |  |  |
| 102                                             | 0x66             | 0.125       | 0    | 0                               | 0.001       | 12.75  | DDR4-2666T-3DS3A    |       |  |  |  |
| 114                                             | 0x72             | 0.125       | 0    | 0                               | 0.001       | 14.25  | DDR4-2666V-3DS3A    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2666W-3DS4A    |       |  |  |  |
| 120                                             | 0x78             | 0.125       | 0    | 0                               | 0.001       | 15.00  | DDR4-2666W-D-3DS4A  | 2     |  |  |  |
|                                                 |                  | 0.125       |      |                                 | 0.001       | tbd    | DDR4-2933tbd-3DStbd |       |  |  |  |
|                                                 |                  | 0.125       |      |                                 | 0.001       | tbd    | DDR4-2933tbd-3DStbd |       |  |  |  |
|                                                 |                  | 0.125       |      |                                 | 0.001       | tbd    | DDR4-2933tbd-3DStbd |       |  |  |  |

Table 52 — Examples of Minimum Row Precharge Delay Time (Cont'd)

|        | omin<br>units) | MTB<br>(ns) |      | o Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>RP</sub> min<br>Result<br>(ns) | Use                 | Notes |
|--------|----------------|-------------|------|---------------------------------|-------------|---------------------------------------|---------------------|-------|
| 100    | 0x64           | 0.125       | 0    | 0                               | 0.001       | 12.50                                 | DDR4-3200W-3DS4A    |       |
| 107    | 0x6B           | 0.125       | -105 | 0x97                            | 0.001       | 13.27                                 | DDR4-3200AA-3DS4A   |       |
| 120    | 0x78           | 0.125       | 0    | 0                               | 0.001       | 15.00                                 | DDR4-3200AC-3DS4A   |       |
| 120    | 0x78           | 0.125       | 0    | 0                               | 0.001       | 15.00                                 | DDR4-3200AC-D-3DS4A | 2     |
| NOTE 1 |                |             |      |                                 |             |                                       |                     |       |

## 8.1.25 Byte 27 (0x01B): Upper Nibbles for t<sub>RAS</sub>min and t<sub>RC</sub>min

This byte, shown in Table 53, defines the most significant nibbles for the values of  $t_{RAS}$ min (byte 28) and  $t_{RC}$ min (byte 29). These values come from the DDR4 SDRAM data sheet.

Table 53 — Byte 27 (0x01B): Upper Nibbles for  $t_{RAS}$ min and  $t_{RC}$ min

| Bits 7~4                                    | Bits 3~0                                     |  |  |
|---------------------------------------------|----------------------------------------------|--|--|
| t <sub>RC</sub> min Most Significant Nibble | t <sub>RAS</sub> min Most Significant Nibble |  |  |
| See Byte 28 description                     | See Byte 29 description                      |  |  |

#### 8.1.26 Byte 28 (0x01C): Minimum Active to Precharge Delay Time (t<sub>RAS</sub>min), Least Significant Byte

The lower nibble of Byte 27 and the contents of Byte 28, shown in Table 54, combined create a 12-bit value which defines the minimum SDRAM Active to Precharge Delay Time in medium timebase (MTB) units. The most significant bit is Bit 3 of Byte 27, and the least significant bit is Bit 0 of Byte 28. This value comes from the DDR4 SDRAM data sheet.

Table 54 — Byte 28 (0x01C): Minimum Active to Precharge Delay Time (t<sub>RAS</sub>min), Least Significant Byte

|                                                         | Byte 27 Bits 3~0, Byte 28 Bits 7~0 |  |  |
|---------------------------------------------------------|------------------------------------|--|--|
| Minimum Active to Precharge Time (t <sub>RAS</sub> min) |                                    |  |  |
|                                                         | MTB Units                          |  |  |
| Values defined from 1 to 4095                           |                                    |  |  |

**Examples:** See Table 55.

Table 55 — Examples of Minimum Active to Precharge Delay Time

| t <sub>RAS</sub> min |          | MTB   | t <sub>RAS</sub> min Result | 11            |
|----------------------|----------|-------|-----------------------------|---------------|
| (MTE                 | 3 units) | (ns)  | (ns)                        | Use           |
| 280                  | 0x118    | 0.125 | 35                          | DDR4-1600     |
| 272                  | 0x110    | 0.125 | 34                          | DDR4-1866     |
| 264                  | 0x108    | 0.125 | 33                          | DDR4-2133     |
| 256                  | 0x100    | 0.125 | 32                          | DDR4-2400     |
| 256                  | 0x100    | 0.125 | 32                          | DDR4-2666     |
| 256                  | 0x100    | 0.125 | 32                          | DDR4-2933     |
| 256                  | 0x100    | 0.125 | 32                          | DDR4-3200     |
| 280                  | 0x118    | 0.125 | 35                          | DDR4-1600-3DS |
| 272                  | 0x110    | 0.125 | 34                          | DDR4-1866-3DS |
| 264                  | 0x108    | 0.125 | 33                          | DDR4-2133-3DS |
| 256                  | 0x100    | 0.125 | 32                          | DDR4-2400-3DS |
| 256                  | 0x100    | 0.125 | 32                          | DDR4-2666-3DS |
|                      |          | 0.125 | tbd                         | DDR4-2933-3DS |
| 256                  | 0x100    | 0.125 | 32                          | DDR4-3200-3DS |

#### 8.1.27 Byte 29 (0x01D): Minimum Active to Active/Refresh Delay Time (t<sub>RC</sub>min), Least Significant Byte

The upper nibble of Byte 27 and the contents of Byte 29, shown in Table 56, combined create a 12-bit value which defines the minimum SDRAM Active to Active/Refresh Delay Time in medium timebase (MTB) units. The most significant bit is Bit 7 of Byte 27, and the least significant bit is Bit 0 of Byte 29. This value comes from the DDR4 SDRAM data sheet.

Table 56 — Byte 29 (0x01D): Minimum Active to Active/Refresh Delay Time (t<sub>RC</sub>min), Least Significant Byte

|                                                             | Byte 27 Bits 7~4, Byte 29 Bits 7~0 |  |  |  |
|-------------------------------------------------------------|------------------------------------|--|--|--|
| Minimum Active to Active/Refresh Time (t <sub>RC</sub> min) |                                    |  |  |  |
|                                                             | MTB Units                          |  |  |  |
| Values defined from 1 to 4095                               |                                    |  |  |  |

If  $t_{RC}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{RC}$ min (SPD byte 120) used for correction to get the actual value.

By DDR4 device design,  $t_{RC}$ min must always be greater than or equal to  $t_{RAS}$ min +  $t_{RP}$ min. When converting time in ns to nCK units using the appropriate rounding algorithms for these three parameters, systems must account for the overall design requirement and choose the larger of  $t_{RC}$ min or ( $t_{RAS}$ min +  $t_{RP}$ min) as a minimum setting.

**Examples:** See Table 57.

Table 57 — Examples of Minimum Active to Active/Refresh Delay Time

|     | <sub>C</sub> min<br>3 units) | MTB<br>(ns) |      | n Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>RC</sub> min<br>Result<br>(ns) | Use          | Notes |
|-----|------------------------------|-------------|------|---------------------------------|-------------|---------------------------------------|--------------|-------|
| 380 | 0x17C                        | 0.125       | 0    | 0                               | 0.001       | 47.50                                 | DDR4-1600J   |       |
| 390 | 0x186                        | 0.125       | 0    | 0                               | 0.001       | 48.75                                 | DDR4-1600K   |       |
| 388 | 0x184                        | 0.125       | 0    | 0                               | 0.001       | 48.50                                 | DDR4-1600K-D | 2     |
| 400 | 0x190                        | 0.125       | 0    | 0                               | 0.001       | 50.00                                 | DDR4-1600L   |       |
| 375 | 0x177                        | 0.125       | -25  | 0xE7                            | 0.001       | 46.85                                 | DDR4-1866L   |       |
| 384 | 0x180                        | 0.125       | -80  | 0xB0                            | 0.001       | 47.92                                 | DDR4-1866M   |       |
| 380 | 0x17C                        | 0.125       | 0    | 0                               | 0.001       | 47.50                                 | DDR4-1866M-D | 2     |
| 392 | 0x188                        | 0.125       | 0    | 0                               | 0.001       | 49.00                                 | DDR4-1866N   |       |
| 370 | 0x172                        | 0.125       | -120 | 0x88                            | 0.001       | 46.13                                 | DDR4-2133N   |       |
| 377 | 0x179                        | 0.125       | -65  | 0xBF                            | 0.001       | 47.06                                 | DDR4-2133P   |       |
| 372 | 0x174                        | 0.125       | 0    | 0                               | 0.001       | 46.50                                 | DDR4-2133P-D | 2     |
| 384 | 0x180                        | 0.125       | 0    | 0                               | 0.001       | 48.00                                 | DDR4-2133R   |       |
| 356 | 0x164                        | 0.125       | 0    | 0                               | 0.001       | 44.50                                 | DDR4-2400P   |       |
| 363 | 0x16B                        | 0.125       | -55  | 0xC9                            | 0.001       | 45.32                                 | DDR4-2400R   |       |
| 370 | 0x172                        | 0.125       | -91  | 0xA5                            | 0.001       | 46.16                                 | DDR4-2400T   |       |
| 366 | 0x16E                        | 0.125       | 0    | 0                               | 0.001       | 45.75                                 | DDR4-2400T-D | 2     |
| 376 | 0x178                        | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2400U   |       |
| 358 | 0x166                        | 0.125       | 0    | 0                               | 0.001       | 44.75                                 | DDR4-2666T   |       |
| 364 | 0x16C                        | 0.125       | 0    | 0                               | 0.001       | 45.50                                 | DDR4-2666U   |       |
| 370 | 0x172                        | 0.125       | 0    | 0                               | 0.001       | 46.25                                 | DDR4-2666V   |       |
| 366 | 0x16E                        | 0.125       | 0    | 0                               | 0.001       | 45.75                                 | DDR4-2666V-D | 2     |
| 376 | 0x178                        | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2666W   |       |
| 360 | 0x168                        | 0.125       | -40  | 0xD8                            | 0.001       | 44.96                                 | DDR4-2933V   |       |
| 366 | 0x16E                        | 0.125       | -110 | 0x92                            | 0.001       | 45.64                                 | DDR4-2933W   |       |
| 371 | 0x173                        | 0.125       | -55  | 0xC9                            | 0.001       | 46.32                                 | DDR4-2933Y   |       |
| 366 | 0x16E                        | 0.125       | 0    | 0                               | 0.001       | 45.75                                 | DDR4-2933Y-D | 2     |
| 376 | 0x178                        | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2933AA  |       |
| 356 | 0x164                        | 0.125       | 0    | 0                               | 0.001       | 44.50                                 | DDR4-3200W   |       |
| 366 | 0x16E                        | 0.125       | 0    | 0                               | 0.001       | 45.75                                 | DDR4-3200AA  |       |
| 376 | 0x178                        | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-3200AB  |       |

|     |                                                                                                                     |             | F    |                                 |             |                                       | ·                   |       |
|-----|---------------------------------------------------------------------------------------------------------------------|-------------|------|---------------------------------|-------------|---------------------------------------|---------------------|-------|
|     | <sub>C</sub> min<br>3 units)                                                                                        | MTB<br>(ns) | _    | n Offset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>RC</sub> min<br>Result<br>(ns) | Use                 | Notes |
| 380 | 0x17C                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.50                                 | DDR4-1600J-3DS2B    |       |
| 390 | 0x186                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 48.75                                 | DDR4-1600K-3DS2B    |       |
| 400 | 0x190                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 50.00                                 | DDR4-1600L-3DS2B    |       |
| 375 | 0x177                                                                                                               | 0.125       | -25  | 0xE7                            | 0.001       | 46.85                                 | DDR4-1866L-3DS2B    |       |
| 375 | 0x177                                                                                                               | 0.125       | -25  | 0xE7                            | 0.001       | 46.85                                 | DDR4-1866L-D-3DS2B  | 2     |
| 384 | 0x180                                                                                                               | 0.125       | -80  | 0xB0                            | 0.001       | 47.92                                 | DDR4-1866M-3DS2B    |       |
| 384 | 0x180                                                                                                               | 0.125       | -80  | 0xB0                            | 0.001       | 47.92                                 | DDR4-1866M-D-3DS2B  | 2     |
| 392 | 0x188                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 49.00                                 | DDR4-1866N-3DS2B    |       |
| 377 | 0x179                                                                                                               | 0.125       | -65  | 0xBF                            | 0.001       | 47.06                                 | DDR4-2133P-3DS2A    |       |
| 377 | 0x179                                                                                                               | 0.125       | -65  | 0xBF                            | 0.001       | 47.06                                 | DDR4-2133P-D-3DS2A  | 2     |
| 377 | 0x179                                                                                                               | 0.125       | -65  | 0xBF                            | 0.001       | 47.06                                 | DDR4-2133R-3DS3A    |       |
| 384 | 0x180                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 48.00                                 | DDR4-2133R-3DS4A    |       |
| 384 | 0x180                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 48.00                                 | DDR4-2133R-D-3DS4A  | 2     |
| 356 | 0x164                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 44.50                                 | DDR4-2400P-3DS3B    |       |
| 370 | 0x172                                                                                                               | 0.125       | -91  | 0xA5                            | 0.001       | 46.16                                 | DDR4-2400T-3DS2A    |       |
| 376 | 0x178                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2400U-3DS2A    |       |
| 376 | 0x178                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2400U-3DS4A    |       |
| 376 | 0x178                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2400U-D-3DS4A  | 2     |
| 358 | 0x166                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 44.75                                 | DDR4-2666T-3DS3A    |       |
| 370 | 0x172                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 46.25                                 | DDR4-2666V-3DS3A    |       |
| 376 | 0x178                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2666W-3DS4A    |       |
| 376 | 0x178                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-2666W-D-3DS4A  | 2     |
|     |                                                                                                                     | 0.125       |      |                                 | 0.001       | tbd                                   | DDR4-2933tbd-3DStbd |       |
|     |                                                                                                                     | 0.125       |      |                                 | 0.001       | tbd                                   | DDR4-2933tbd-3DStbd |       |
|     |                                                                                                                     | 0.125       |      |                                 | 0.001       | tbd                                   | DDR4-2933tbd-3DStbd |       |
| 356 | 0x164                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 44.50                                 | DDR4-3200W-3DS4A    |       |
| 363 | 0x16B                                                                                                               | 0.125       | -105 | 0x97                            | 0.001       | 45.27                                 | DDR4-3200AA-3DS4A   |       |
| 376 | 0x178                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-3200AC-3DS4A   |       |
| 376 | 0x178                                                                                                               | 0.125       | 0    | 0                               | 0.001       | 47.00                                 | DDR4-3200AC-D-3DS4A | 2     |
|     | NOTE 1 See SPD byte 120 NOTE 2 Device supports downbinning in lower frequency applications; see supplier data sheet |             |      |                                 |             |                                       |                     |       |

Table 57 — Examples of Minimum Active to Active/Refresh Delay Time (Cont'd)

# 8.1.28 Byte 30 (0x01E): Minimum Refresh Recovery Delay Time (t<sub>RFC1</sub>min), Least Significant Byte Byte 31 (0x01F): Minimum Refresh Recovery Delay Time (t<sub>RFC1</sub>min), Most Significant Byte

This word, shown in Table 58, defines the minimum SDRAM Refresh Recovery Time Delay in medium timebase (MTB) units. These values come from the DDR4 SDRAM data sheet.

Table 58 — Bytes 30 and 31, Minimum Refresh Recovery Delay Time (t<sub>RFC1</sub>min)

| Minimum SDRAM Refresh Recovery Delay Time (t <sub>RFC1</sub> min) MTB Units |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Byte 31 Byte 30                                                             |  |  |  |  |  |  |  |
| Bits 15~8 Bits 7~0                                                          |  |  |  |  |  |  |  |
| Values defined from 1 to 65535                                              |  |  |  |  |  |  |  |

Examples: See Table 59.

Table 59 — Examples of Minimum Refresh Recovery Delay Time (t<sub>RFC1</sub>min)

|                                                                                       | t <sub>RFC1</sub> min<br>(MTB units) |       | t <sub>RFC1</sub> min Result<br>(ns) | Use              |  |  |  |
|---------------------------------------------------------------------------------------|--------------------------------------|-------|--------------------------------------|------------------|--|--|--|
| 1280                                                                                  | 1280 0x0500                          |       | 160                                  | 2 Gb DDR4 SDRAM  |  |  |  |
| 2080                                                                                  | 2080 0x0820 0.1                      |       | 260                                  | 4 Gb DDR4 SDRAM  |  |  |  |
| 2800                                                                                  | 2800 0x0AF0 0.12                     |       | 350                                  | 8 Gb DDR4 SDRAM  |  |  |  |
| 4400                                                                                  | 0x1130                               | 0.125 | 550                                  | 16 Gb DDR4 SDRAM |  |  |  |
| NOTE 1 For 3DS, tRFC1 refers to the tRFC_slr1. See the DDR4 3DS Addendum for details. |                                      |       |                                      |                  |  |  |  |

# 8.1.29 Byte 32 (0x020): Minimum Refresh Recovery Delay Time (t<sub>RFC2</sub>min), Least Significant Byte Byte 33 (0x021): Minimum Refresh Recovery Delay Time (t<sub>RFC2</sub>min), Most Significant Byte

This word, shown in Table 60, defines the minimum SDRAM Refresh Recovery Time Delay in medium timebase (MTB) units. These values come from the DDR4 SDRAM data sheet.

Table 60 — Bytes 32 and 33, Minimum Refresh Recovery Delay Time (t<sub>RFC2</sub>min)

|                                | ecovery Delay Time (t <sub>RFC2</sub> min)<br>Units |
|--------------------------------|-----------------------------------------------------|
| Byte 33                        | Byte 32                                             |
| Bits 15~8                      | Bits 7~0                                            |
| Values defined from 1 to 65535 |                                                     |

Examples: See Table 61.

Table 61 — Examples of Minimum Refresh Recovery Delay Time (t<sub>RFC2</sub>min)

|             | t <sub>RFC2</sub> min<br>(MTB units)                                                  |       | t <sub>RFC2</sub> min Result<br>(ns) | Use              |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------|-------|--------------------------------------|------------------|--|--|--|--|
| 880         | 880 0x0370                                                                            |       | 110                                  | 2 Gb DDR4 SDRAM  |  |  |  |  |
| 1280 0x0500 |                                                                                       | 0.125 | 160                                  | 4 Gb DDR4 SDRAM  |  |  |  |  |
| 2080        | 2080 0x0820 0.125                                                                     |       | 260                                  | 8 Gb DDR4 SDRAM  |  |  |  |  |
| 2800        | 0x0AF0                                                                                | 0.125 | 350                                  | 16 Gb DDR4 SDRAM |  |  |  |  |
| NOTE 1      | NOTE 1 For 3DS, tRFC2 refers to the tRFC_slr2. See the DDR4 3DS Addendum for details. |       |                                      |                  |  |  |  |  |

# 8.1.30 Byte 34 (0x022): Minimum Refresh Recovery Delay Time (t<sub>RFC4</sub>min), Least Significant Byte Byte 35 (0x023): Minimum Refresh Recovery Delay Time (t<sub>RFC4</sub>min), Most Significant Byte

This word, shown in Table 62, defines the minimum SDRAM Refresh Recovery Time Delay in medium timebase (MTB) units. These values come from the DDR4 SDRAM data sheet.

Table 62 — Bytes 34 and 35, Minimum Refresh Recovery Delay Time (t<sub>RFC4</sub>min)

| Minimum SDRAM Refresh Recovery Delay Time (t <sub>RFC4</sub> min) MTB Units |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Byte 35 Byte 34                                                             |  |  |  |  |  |  |  |
| Bits 15~8 Bits 7~0                                                          |  |  |  |  |  |  |  |
| Values defined from 1 to 65535                                              |  |  |  |  |  |  |  |

Examples: See Table 63.

Table 63 — Examples of Minimum Refresh Recovery Delay Time (t<sub>RFC4</sub>min)

|                                                                                       | t <sub>RFC4</sub> min<br>(MTB units) |  | t <sub>RFC4</sub> min Result<br>(ns) | Use             |  |  |  |
|---------------------------------------------------------------------------------------|--------------------------------------|--|--------------------------------------|-----------------|--|--|--|
| 720                                                                                   | 720 0x02D0                           |  | 90                                   | 2 Gb DDR4 SDRAM |  |  |  |
| 880                                                                                   | 0x0370 0.125                         |  | 110                                  | 4 Gb DDR4 SDRAM |  |  |  |
| 1280                                                                                  | 1280 0x0500 0.125                    |  | 160                                  | 8 Gb DDR4 SDRAM |  |  |  |
| 2080 0x0820 0.125 260 16 Gb DDR4 SDRAM                                                |                                      |  |                                      |                 |  |  |  |
| NOTE 1 For 3DS, tRFC4 refers to the tRFC_slr4. See the DDR4 3DS Addendum for details. |                                      |  |                                      |                 |  |  |  |

## 8.1.31 Byte 36 (0x024): Upper Nibble for t<sub>FAW</sub>

This byte, shown in Table 64, defines the most significant nibble for the value of  $t_{FAW}$  (SPD byte 37). This value comes from the DDR4 SDRAM data sheet.

Table 64 — Byte 36 (0x024): Upper Nibble for  $t_{FAW}$ 

| Bits 7 ~ 4                      | Bits 3 ~ 0                               |  |  |
|---------------------------------|------------------------------------------|--|--|
| Reserved                        | t <sub>FAW</sub> Most Significant Nibble |  |  |
| Reserved; most be coded as 0000 | See Byte 37 description                  |  |  |

## 8.1.32 Byte 37 (0x025): Minimum Four Activate Window Delay Time (t<sub>FAW</sub>min), Least Significant Byte

The lower nibble of Byte 36 and the contents of Byte 37, shown in Table 65, combined create a 12-bit value which defines the minimum SDRAM Four Activate Window Delay Time in medium timebase (MTB) units. This value comes from the DDR4 SDRAM data sheet. The value of this number may be dependent on the SDRAM page size; please refer to the DDR4 SDRAM data sheet section on Addressing to determine the page size for these devices.

Table 65 — Byte 37 (0x025): Minimum Four Activate Window Delay Time (t<sub>FAW</sub>min), Least Significant Byte

| Byte 36 Bits 3 ~ 0, Byte 37 Bits 7 ~ 0                      |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Minimum Four Activate Window Delay Time (t <sub>FAW</sub> ) |  |  |  |  |  |  |  |  |
| MTB Units                                                   |  |  |  |  |  |  |  |  |
| Values defined from 1 to 4095                               |  |  |  |  |  |  |  |  |

Examples: See Table 66.

Table 66 — Examples of Minimum Four Activate Window Delay Time

| tF   | AW       | Timebase | tFAW Result |                             | Notes |
|------|----------|----------|-------------|-----------------------------|-------|
| (MTE | 3 units) | (ns)     | (ns)        | Use                         | Notes |
| 280  | 0x118    | 0.125    | 35          | DDR4-1600, 2 KB page size   |       |
| 200  | 0x0C8    | 0.125    | 25          | DDR4-1600, 1 KB page size   |       |
| 160  | 0x0A0    | 0.125    | 20          | DDR4-1600, 1/2 KB page size |       |
| 240  | 0x0F0    | 0.125    | 30          | DDR4-1866, 2 KB page size   |       |
| 184  | 0x0B8    | 0.125    | 23          | DDR4-1866, 1 KB page size   |       |
| 136  | 0x088    | 0.125    | 17          | DDR4-1866, 1/2 KB page size |       |
| 240  | 0x0F0    | 0.125    | 30          | DDR4-2133, 2 KB page size   |       |
| 168  | 0x0A8    | 0.125    | 21          | DDR4-2133, 1 KB page size   |       |
| 120  | 0x078    | 0.125    | 15          | DDR4-2133, 1/2 KB page size |       |
| 240  | 0x0F0    | 0.125    | 30          | DDR4-2400, 2 KB page size   |       |
| 168  | 0x0A8    | 0.125    | 21          | DDR4-2400, 1 KB page size   |       |
| 104  | 0x068    | 0.125    | 13          | DDR4-2400, 1/2 KB page size |       |
| 240  | 0x0F0    | 0.125    | 30          | DDR4-2666, 2 KB page size   |       |
| 168  | 0x0A8    | 0.125    | 21          | DDR4-2666, 1 KB page size   |       |
| 96   | 0x060    | 0.125    | 12          | DDR4-2666, 1/2 KB page size |       |
| 240  | 0x0F0    | 0.125    | 30          | DDR4-2933, 2 KB page size   |       |
| 168  | 0x0A8    | 0.125    | 21          | DDR4-2933, 1 KB page size   |       |
| 88   | 0x058    | 0.125    | 10.875      | DDR4-2933, 1/2 KB page size |       |
| 240  | 0x0F0    | 0.125    | 30          | DDR4-3200, 2 KB page size   |       |
| 168  | 0x0A8    | 0.125    | 21          | DDR4-3200, 1 KB page size   |       |
| 80   | 0x050    | 0.125    | 10          | DDR4-3200, 1/2 KB page size |       |
| 160  | 0x0A0    | 0.125    | 20          | DDR4-1600-3DS, x4           | 1     |
| 200  | 0x0C8    | 0.125    | 25          | DDR4-1600-3DS, x8           | 1     |
| 136  | 0x088    | 0.125    | 17          | DDR4-1866-3DS, x4           | 1     |
| 184  | 0x0B8    | 0.125    | 23          | DDR4-1866-3DS, x8           | 1     |
| 120  | 0x078    | 0.125    | 15          | DDR4-2133-3DS, x4           | 1     |
| 168  | 0x0A8    | 0.125    | 21          | DDR4-2133-3DS, x8           | 1     |
| 104  | 0x068    | 0.125    | 13          | DDR4-2400-3DS, x4           | 1     |
| 168  | 0x0A8    | 0.125    | 21          | DDR4-2400-3DS, x8           | 1     |
|      |          | 0.125    | tbd         | DDR4-2666-3DS, x4           | 1     |
|      |          | 0.125    | tbd         | DDR4-2666-3DS, x8           | 1     |
|      |          | 0.125    | tbd         | DDR4-2933-3DS, x4           | 1     |
|      |          | 0.125    | tbd         | DDR4-2933-3DS, x8           | 1     |
|      |          | 0.125    | tbd         | DDR4-3200-3DS, x4           | 1     |
|      |          | 0.125    | tbd         | DDR4-3200-3DS, x8           | 1     |

NOTE 1 For 3DS, tFAW refers to the tFAW\_slr\_x4 or tFAW\_slr\_x8 parameter depending on the I/O organization of the device. See the DDR4 3DS Addendum for details.

## 8.1.33 Byte 38 (0x026): Minimum Activate to Activate Delay Time ( $t_{RRD\ S}$ min), Different Bank Group

This byte, shown in Table 67, defines the minimum SDRAM Activate to Activate Delay Time to different bank groups in medium timebase (MTB) units. This value comes from the DDR4 SDRAM data sheet. Controller designers must also note that at some frequencies, a minimum number of clocks may be required resulting in a larger t<sub>RRD\_S</sub>min value than indicated in the SPD. For example, t<sub>RRD\_S</sub>min for DDR4-1600 must be 4 clocks.

Table 67 — Byte 38 (0x026): Minimum Activate to Activate Delay Time (t<sub>RRD</sub> <sub>S</sub>min), Different Bank Group

|                              | Bits 7~0                                                                  |
|------------------------------|---------------------------------------------------------------------------|
|                              | Minimum Active to Active/Refresh Time (t <sub>RRD_S</sub> min)  MTB Units |
| Values defined from 1 to 255 | m15 onto                                                                  |

If  $t_{RRD\_S}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{RRD\_S}$ min (SPD byte 119) used for correction to get the actual value.

Examples: See Table 68.

Table 68 — Examples of Minimum Activate to Activate Delay Time, Different Bank Group

| t <sub>RRD_S</sub> min<br>(MTB units) |      | MTB<br>(ns) | t <sub>RRD_S</sub> min<br>Offset<br>(FTB units) <sup>1</sup> | ffset | FTB<br>(ns) | min<br>Result<br>(ns) | Use                         | Notes |
|---------------------------------------|------|-------------|--------------------------------------------------------------|-------|-------------|-----------------------|-----------------------------|-------|
| 48                                    | 0x30 | 0.125       | 0                                                            | 0     | 0.001       | 6.00                  | DDR4-1600, 2 KB page size   |       |
| 40                                    | 0x28 | 0.125       | 0                                                            | 0     | 0.001       | 5.00                  | DDR4-1600, 1 KB page size   |       |
| 40                                    | 0x28 | 0.125       | 0                                                            | 0     | 0.001       | 5.00                  | DDR4-1600, 1/2 KB page size |       |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4  | 0.001       | 5.30                  | DDR4-1866, 2 KB page size   |       |
| 34                                    | 0x22 | 0.125       | -50                                                          | 0xCE  | 0.001       | 4.20                  | DDR4-1866, 1 KB page size   |       |
| 34                                    | 0x22 | 0.125       | -50                                                          | 0xCE  | 0.001       | 4.20                  | DDR4-1866, 1/2 KB page size |       |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4  | 0.001       | 5.30                  | DDR4-2133, 2 KB page size   |       |
| 30                                    | 0x1E | 0.125       | -50                                                          | 0xCE  | 0.001       | 3.70                  | DDR4-2133, 1 KB page size   |       |
| 30                                    | 0x1E | 0.125       | -50                                                          | 0xCE  | 0.001       | 3.70                  | DDR4-2133, 1/2 KB page size |       |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4  | 0.001       | 5.30                  | DDR4-2400, 2 KB page size   |       |
| 27                                    | 0x1B | 0.125       | -76                                                          | 0xB4  | 0.001       | 3.30                  | DDR4-2400, 1 KB page size   |       |
| 27                                    | 0x1B | 0.125       | -76                                                          | 0xB4  | 0.001       | 3.30                  | DDR4-2400, 1/2 KB page size |       |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4  | 0.001       | 5.30                  | DDR4-2666, 2 KB page size   |       |
| 24                                    | 0x18 | 0.125       | 0                                                            | 0     | 0.001       | 3.00                  | DDR4-2666, 1 KB page size   |       |
| 24                                    | 0x18 | 0.125       | 0                                                            | 0     | 0.001       | 3.00                  | DDR4-2666, 1/2 KB page size |       |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4  | 0.001       | 5.30                  | DDR4-2933, 2 KB page size   |       |
| 22                                    | 0x16 | 0.125       | -50                                                          | 0xCE  | 0.001       | 2.70                  | DDR4-2933, 1 KB page size   |       |
| 22                                    | 0x16 | 0.125       | -50                                                          | 0xCE  | 0.001       | 2.70                  | DDR4-2933, 1/2 KB page size |       |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4  | 0.001       | 5.30                  | DDR4-3200, 2 KB page size   |       |
| 20                                    | 0x14 | 0.125       | 0                                                            | 0     | 0.001       | 2.50                  | DDR4-3200, 1 KB page size   |       |
| 20                                    | 0x14 | 0.125       | 0                                                            | 0     | 0.001       | 2.50                  | DDR4-3200, 1/2 KB page size |       |
| 40                                    | 0x28 | 0.125       | 0                                                            | 0     | 0.001       | 5.00                  | DDR4-1600-3DS               | 2     |
| 34                                    | 0x22 | 0.125       | -50                                                          | 0xCE  | 0.001       | 4.20                  | DDR4-1866-3DS               | 2     |
| 30                                    | 0x1E | 0.125       | -50                                                          | 0xCE  | 0.001       | 3.70                  | DDR4-2133-3DS               | 2     |
| 27                                    | 0x1B | 0.125       | -75                                                          | 0xB4  | 0.001       | 3.30                  | DDR4-2400-3DS               | 2     |
|                                       |      | 0.125       |                                                              |       | 0.001       | tbd                   | DDR4-2666-3DS               | 2     |
|                                       |      | 0.125       |                                                              |       | 0.001       | tbd                   | DDR4-2933-3DS               | 2     |
|                                       |      | 0.125       |                                                              |       | 0.001       | tbd                   | DDR4-3200-3DS               | 2     |

## 8.1.34 Byte 39 (0x027): Minimum Activate to Activate Delay Time (t<sub>RRD\_L</sub>min), Same Bank Group

This byte, shown in Table 69, defines the minimum SDRAM Activate to Activate Delay Time to the same bank group in medium timebase (MTB) units. This value comes from the DDR4 SDRAM data sheet. Controller designers must also note that at some

frequencies, a minimum number of clocks may be required resulting in a larger t<sub>RRD</sub> <sub>L</sub>min value than indicated in the SPD. For example,  $t_{\mbox{\scriptsize RRD}}$  Lmin for DDR4-1600 must be 4 clocks.

Table 69 — Byte 39 (0x027): Minimum Activate to Activate Delay Time (t<sub>RRD L</sub>min), Same Bank Group

|                              | Bits 7~0                                                       |  |  |  |  |  |  |  |  |
|------------------------------|----------------------------------------------------------------|--|--|--|--|--|--|--|--|
|                              | Minimum Active to Active/Refresh Time (t <sub>RRD_L</sub> min) |  |  |  |  |  |  |  |  |
|                              | MTB Units                                                      |  |  |  |  |  |  |  |  |
| Values defined from 1 to 255 |                                                                |  |  |  |  |  |  |  |  |

If t<sub>RRD</sub> I min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for t<sub>RRD L</sub>min (SPD byte 118) used for correction to get the actual value.

Examples: See Table 70.

Table 70 — Examples of Minimum Activate to Activate Delay Time, Same Bank Group

| t <sub>RRD_L</sub> min<br>(MTB units) |      | MTB<br>(ns) | t <sub>RRD_L</sub> min<br>Offset<br>(FTB units) <sup>1</sup> |      | FTB<br>(ns) | t <sub>RRD_L</sub><br>min<br>Result<br>(ns) | Use                         |
|---------------------------------------|------|-------------|--------------------------------------------------------------|------|-------------|---------------------------------------------|-----------------------------|
| 60                                    | 0x3C | 0.125       | 0                                                            | 0    | 0.001       | 7.50                                        | DDR4-1600, 2 KB page size   |
| 48                                    | 0x30 | 0.125       | 0                                                            | 0    | 0.001       | 6.00                                        | DDR4-1600, 1 KB page size   |
| 48                                    | 0x30 | 0.125       | 0                                                            | 0    | 0.001       | 6.00                                        | DDR4-1600, 1/2 KB page size |
| 52                                    | 0x34 | 0.125       | -100                                                         | 0x9C | 0.001       | 6.40                                        | DDR4-1866, 2 KB page size   |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4 | 0.001       | 5.30                                        | DDR4-1866, 1 KB page size   |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4 | 0.001       | 5.30                                        | DDR4-1866, 1/2 KB page size |
| 52                                    | 0x34 | 0.125       | -100                                                         | 0x9C | 0.001       | 6.40                                        | DDR4-2133, 2 KB page size   |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4 | 0.001       | 5.30                                        | DDR4-2133, 1 KB page size   |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4 | 0.001       | 5.30                                        | DDR4-2133, 1/2 KB page size |
| 52                                    | 0x34 | 0.125       | -100                                                         | 0x9C | 0.001       | 6.40                                        | DDR4-2400, 2 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-2400, 1 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-2400, 1/2 KB page size |
| 52                                    | 0x34 | 0.125       | -100                                                         | 0x9C | 0.001       | 6.40                                        | DDR4-2666, 2 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-2666, 1 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-2666, 1/2 KB page size |
| 52                                    | 0x34 | 0.125       | -100                                                         | 0x9C | 0.001       | 6.40                                        | DDR4-2933, 2 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-2933, 1 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-2933, 1/2 KB page size |
| 52                                    | 0x34 | 0.125       | -100                                                         | 0x9C | 0.001       | 6.40                                        | DDR4-3200, 2 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-3200, 1 KB page size   |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-3200, 1/2 KB page size |
| 48                                    | 0x30 | 0.125       | 0                                                            | 0    | 0.001       | 6.00                                        | DDR4-1600-3DS               |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4 | 0.001       | 5.30                                        | DDR4-1866-3DS               |
| 43                                    | 0x2B | 0.125       | -76                                                          | 0xB4 | 0.001       | 5.30                                        | DDR4-2133-3DS               |
| 40                                    | 0x28 | 0.125       | -100                                                         | 0x9C | 0.001       | 4.90                                        | DDR4-2400-3DS               |
|                                       |      | 0.125       |                                                              |      | 0.001       | tbd                                         | DDR4-2666-3DS               |
|                                       |      | 0.125       |                                                              |      | 0.001       | tbd                                         | DDR4-2933-3DS               |
|                                       |      | 0.125       |                                                              |      | 0.001       | tbd                                         | DDR4-3200-3DS               |

NOTE 2 For 3DS, tRRD L refers to the tRRD L slr parameter. See the DDR4 3DS Addendum for details.

## 8.1.35 Byte 40 (0x028): Minimum CAS to CAS Delay Time ( $t_{CCD\ L}$ min), Same Bank Group

This byte, shown in Table 71, defines the minimum SDRAM CAS to CAS Delay Time to the same bank group in medium timebase (MTB) units. This value comes from the DDR4 SDRAM data sheet. Controller designers must also note that at some frequencies, a

#### 8.1.35 Byte 40 (0x028): Minimum CAS to CAS Delay Time (t<sub>CCD\_L</sub>min), Same Bank Group (Cont'd)

minimum number of clocks may be required resulting in a larger  $t_{CCD\_L}$ min value than indicated in the SPD. For example,  $t_{CCD\_L}$ min for DDR4-2133 must be 6 clocks.

Table 71 — Byte 40 (0x028): Minimum CAS to CAS Delay Time (t<sub>CCD L</sub>min), Same Bank Group

|                                                  | Bits 7~0  |  |  |  |  |  |
|--------------------------------------------------|-----------|--|--|--|--|--|
| Minimum CAS to CAS Time (t <sub>CCD_L</sub> min) |           |  |  |  |  |  |
|                                                  | MTB Units |  |  |  |  |  |
| Values defined from 1 to 255                     |           |  |  |  |  |  |

If  $t_{CCD\_L}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{CCD\_L}$ min (SPD byte 117) used for correction to get the actual value.

Examples: See Table 72.

Table 72 — Examples of Minimum CAS to CAS Delay Time, Same Bank Group

|    | <sub>D_L</sub> min<br>B units) | MTB<br>(ns) | Of  | min<br>fset<br>units) <sup>1</sup> | FTB<br>(ns) | t <sub>CCD_L</sub><br>min<br>Result<br>(ns) | Use           | Notes |
|----|--------------------------------|-------------|-----|------------------------------------|-------------|---------------------------------------------|---------------|-------|
| 50 | 0x32                           | 0.125       | 0   | 0                                  | 0.001       | 6.250                                       | DDR4-1600     |       |
| 43 | 0x2B                           | 0.125       | -20 | 0xEC                               | 0.001       | 5.355                                       | DDR4-1866     |       |
| 43 | 0x2B                           | 0.125       | -20 | 0xEC                               | 0.001       | 5.355                                       | DDR4-2133     |       |
| 40 | 0x28                           | 0.125       | 0   | 0                                  | 0.001       | 5.000                                       | DDR4-2400     |       |
| 40 | 0x28                           | 0.125       | 0   | 0                                  | 0.001       | 5.000                                       | DDR4-2666     |       |
| 40 | 0x28                           | 0.125       | 0   | 0                                  | 0.001       | 5.000                                       | DDR4-2933     |       |
| 40 | 0x28                           | 0.125       | 0   | 0                                  | 0.001       | 5.000                                       | DDR4-3200     |       |
| 50 | 0x32                           | 0.125       | 0   | 0                                  | 0.001       | 6.250                                       | DDR4-1600-3DS | 2, 3  |
| 43 | 0x2B                           | 0.125       | -20 | 0xEC                               | 0.001       | 5.355                                       | DDR4-1866-3DS | 2, 3  |
| 43 | 0x2B                           | 0.125       | -20 | 0xEC                               | 0.001       | 5.355                                       | DDR4-2133-3DS | 2, 3  |
| 40 | 0x28                           | 0.125       | 0   | 0                                  | 0.001       | 5.000                                       | DDR4-2400-3DS | 2, 3  |
|    |                                | 0.125       |     |                                    | 0.001       | tbd                                         | DDR4-2666-3DS | 2, 3  |
|    |                                | 0.125       |     |                                    | 0.001       | tbd                                         | DDR4-2933-3DS | 2, 3  |
|    |                                | 0.125       |     |                                    | 0.001       | tbd                                         | DDR4-3200-3DS | 2, 3  |

NOTE 1 See SPD byte 117.

#### 8.1.36 Byte 41 (0x029): Upper Nibble for twRmin

This byte, shown in Table 73, defines the most significant nibble for the value of  $t_{WR}$ min (byte 42). This value comes from the DDR4 SDRAM data sheet.

Table 73 — Byte 41 (0x029): Upper Nibble for twRmin

| Bits 7~4                        | Bits 3~0                                    |  |  |
|---------------------------------|---------------------------------------------|--|--|
| Reserved                        | t <sub>WR</sub> min Most Significant Nibble |  |  |
| Reserved; must be coded as 0000 | See Byte 42 description                     |  |  |

#### 8.1.37 Byte 42 (0x02A): Minimum Write Recovery Time (twRmin)

The lower nibble of Byte 41 and the contents of Byte 42, shown in Table 74, combined create a 12-bit value which defines the minimum SDRAM Write Recovery Time in medium timebase (MTB) units. The most significant bit is Bit 3 of Byte 41, and the least

NOTE 2 For 3DS, tCCD\_L refers to the tCCD\_L\_sIr parameter. See the DDR4 3DS Addendum for details.

NOTE 3 DS timings are for 4 die per stack or less. Timings for greater than 4 die per stack at TBD.

significant bit is Bit 0 of Byte 42. This value comes from the DDR4 SDRAM data sheet.

Table 74 — Byte 42 (0x02A): Minimum Write Recovery Time (t<sub>WR</sub>min)

|                               | Byte 41 Bits 3~0, Byte 42 Bits 7~0                           |
|-------------------------------|--------------------------------------------------------------|
|                               | Minimum Write Recovery Time (t <sub>WR</sub> min)  MTB Units |
| Values defined from 1 to 4095 |                                                              |

**Examples:** See Table 75.

Table 75 — Examples of Minimum Write Recovery Time

|     | <sub>R</sub> min<br>3 units) | MTB<br>(ns) | t <sub>WR</sub> min Result<br>(ns) | Use            |
|-----|------------------------------|-------------|------------------------------------|----------------|
| 120 | 0x78                         | 0.125       | 15                                 | All DDR4 bins  |
| 360 | 0x168                        | 0.125       | 45                                 | All DDR4E bins |

#### 8.1.38 Byte 43 (0x029): Upper Nibbles for t<sub>WTR</sub>min

This byte, shown in Table 76, defines the most significant nibbles for the values of t<sub>WTR\_S</sub>min (byte 44) and t<sub>WTR\_L</sub>min (byte 45). This value comes from the DDR4 SDRAM data sheet.

Table 76 — Byte 43 (0x029): Upper Nibbles for t<sub>WTR</sub>min

| Bits 7~4                                       | Bits 3~0                                       |
|------------------------------------------------|------------------------------------------------|
| t <sub>WTR_L</sub> min Most Significant Nibble | t <sub>WTR_S</sub> min Most Significant Nibble |
| See Byte 45 description                        | See Byte 44 description                        |

## 8.1.39 Byte 44 (0x02C): Minimum Write to Read Time (t<sub>WTR\_S</sub>min), Different Bank Group

The lower nibble of Byte 43 and the contents of Byte 44, shown in Table 77, combined create a 12-bit value which defines the minimum SDRAM Write to Read Time to different bank groups in medium timebase (MTB) units. The most significant bit is Bit 3 of Byte 43, and the least significant bit is Bit 0 of Byte 44. This value comes from the DDR4 SDRAM data sheet. Controller designers must also note that at some frequencies, a minimum number of clocks may be required resulting in a larger  $t_{WTR\_S}$ min value than indicated in the SPD. For example,  $t_{WTR\_S}$ min must be at least 2 clocks.

Table 77 — Byte 44 (0x02C): Minimum Write to Read Time (t<sub>WTR</sub> <sub>S</sub>min), Different Bank Group

| Byte 43 Bits 3~0, Byte 44 Bits 7~0                                                    |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Minimum Write Recovery Time (t <sub>WTR_S</sub> min), different bank group  MTB Units |  |  |  |  |  |  |
| Values defined from 1 to 4095                                                         |  |  |  |  |  |  |

**Examples:** See Table 78.

Table 78 — Examples of Minimum Write to Read Time, Different Bank Group

|    | t <sub>WTR</sub> min<br>(MTB units) |  |     |                | t <sub>WTR_S</sub> min Result<br>(ns) | Use |
|----|-------------------------------------|--|-----|----------------|---------------------------------------|-----|
| 20 | 20 0x14                             |  | 2.5 | All DDR4 bins  |                                       |     |
|    |                                     |  | TBD | All DDR4E bins |                                       |     |

## 8.1.40 Byte 45 (0x02D): Minimum Write to Read Time (t<sub>WTR L</sub>min), Same Bank Group

The upper nibble of Byte 43 and the contents of Byte 45, shown in Table 79, combined create a 12-bit value which defines the minimum SDRAM Write to Read Time for access to the same bank group in medium timebase (MTB) units. The most significant bit is Bit 7 of Byte 43, and the least significant bit is Bit 0 of Byte 45. This value comes from the DDR4 SDRAM data sheet. Controller designers must also note that at some frequencies, a minimum number of clocks may be required resulting in a larger  $t_{WTR\_L}$ min value than indicated in the SPD. For example,  $t_{WTR\_L}$  min must be at least 4 clocks.

Table 79 — Byte 45 (0x02D): Minimum Write to Read Time (twr. Lmin), Same Bank Group

| Byte 43 Bits 7~4, Byte 45 Bits 7~0                                              |
|---------------------------------------------------------------------------------|
| Minimum Write Recovery Time (t <sub>WTR_L</sub> min), same bank group MTB Units |
| Values defined from 1 to 4095                                                   |

**Examples:** See Table 80.

Table 80 — Examples of Minimum Write to Read Time, Same Bank Group

|    | t <sub>WTR</sub> min<br>(MTB units) |       | t <sub>WTR_L</sub> min Result<br>(ns) | Use            |
|----|-------------------------------------|-------|---------------------------------------|----------------|
| 60 | 0x3C                                | 0.125 | 7.5                                   | All DDR4 bins  |
|    |                                     |       | TBD                                   | All DDR4E bins |

#### 8.1.41 Byte 46~59 (0x02E~0x03B): Reserved, Base Configuration Section

Must be coded as 0x00

#### 8.1.42 Bytes 60~77 (0x03C~0x04D): Connector to SDRAM Bit Mapping

These bytes, shown in Tables 81 and 82, document the connection between data signals at the edge connector of a module to the DDR4 SDRAM inputs pins for package rank 0 of the module. This information is used by the controller to route data onto the correct bit lines for CRC transmission as described in the DDR4 SDRAM data sheet JESD79-4. Each byte describes the mapping for one nibble (four bits) of data. In addition, each SPD byte describes the mapping between package rank 0 bits and equivalent bits in other ranks.

Table 81 — Bytes 60~77 (0x03C~0x04D): Connector to SDRAM Bit Mapping

|   | SPD Byte |       | Connector Bits | SPD Byte |       | Connector Bits | SPD Byte |       | Connector Bits |
|---|----------|-------|----------------|----------|-------|----------------|----------|-------|----------------|
|   | 60       | 0x03C | DQ0-3          | 66       | 0x042 | DQ24-27        | 72       | 0x048 | DQ40-43        |
| Ī | 61       | 0x03D | DQ4-7          | 67       | 0x043 | DQ28-31        | 73       | 0x049 | DQ44-47        |
| Ī | 62       | 0x03E | DQ8-11         | 68       | 0x044 | CB0-3          | 74       | 0x04A | DQ48-51        |
| Ī | 63       | 0x03F | DQ12-15        | 69       | 0x045 | CB4-7          | 75       | 0x04B | DQ52-55        |
| Ī | 64       | 0x040 | DQ16-19        | 70       | 0x046 | DQ32-35        | 76       | 0x04C | DQ56-59        |
|   | 65       | 0x041 | DQ20-23        | 71       | 0x047 | DQ36-39        | 77       | 0x04D | DQ60-63        |

The mapping rules are as follows:

- All bits within a nibble at the edge connector must be wired to the same SDRAM.
- All bits within a byte at the edge connector must be wired to the same SDRAM for x8 and wider SDRAMs.
- Bits within a nibble may be swapped in any order.
- Nibbles may be swapped within a byte.
- Bytes may be wired in any order within the SDRAM width for x16 and wider SDRAMs.

Each SPD byte in the Bit Mapping array is encoded as follows. If the nibble at the edge connector is wired to the lower nibble of a byte at the SDRAM (x8 and wider), then bit 5 is coded as 0. If the nibble at the edge connector is wired to the upper nibble of a byte at the SDRAM, then bit 5 is coded as 1. Bit 5 = 0 for all x4 based modules. Bits  $6 \sim 7$  define the connectivity between bits in different

package ranks.

Table 82 — Bit Mapping Array

| Bits 7 ~ 6                 | Bit 5                                                  | Bits 4 ~ 0           |  |  |
|----------------------------|--------------------------------------------------------|----------------------|--|--|
| Package Rank Map           | Wired to Upper/Lower Nibble                            | Bit Order at SDRAM   |  |  |
| See Package Rank Map table | 0 = lower nibble at SDRAM<br>1 = upper nibble at SDRAM | See Nibble Map table |  |  |

Package Rank Map: Bits 7~6 in each SPD byte define the mapping between bits in Package Rank 0 and other package ranks on the module. The mapping rules are defined in Table 83:

**Table 83 — Mapping Rules** 

|                | Package Rank Map                                                                                                                               |                         |                                      |                                      |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------------|--------------------------------------|--|--|
| Bits 7 ~ 6     | Bit Order at SDRAM                                                                                                                             |                         |                                      |                                      |  |  |
|                | Even package ranks (0, 2, etc.) have the same mapping Odd package ranks (1, 3, etc) map SDRAM data bits relative to Package Rank 0 as follows: |                         |                                      |                                      |  |  |
|                | $DQ0 \rightarrow DQ1$                                                                                                                          | $DQ8 \to DQ9$           | $\text{DQ16} \rightarrow \text{tbd}$ | $\text{DQ24} \rightarrow \text{tbd}$ |  |  |
|                | DQ1 → DQ0                                                                                                                                      | $DQ9 \to DQ8$           | $DQ17 \rightarrow tbd$               | $\text{DQ25} \rightarrow \text{tbd}$ |  |  |
|                | DQ2 → DQ3                                                                                                                                      | $DQ10 \rightarrow DQ11$ | $DQ18 \rightarrow tbd$               | $\text{DQ26} \rightarrow \text{tbd}$ |  |  |
| 00             | $DQ3 \rightarrow DQ2$                                                                                                                          | $DQ11 \rightarrow DQ10$ | $\text{DQ19} \rightarrow \text{tbd}$ | $\text{DQ27} \rightarrow \text{tbd}$ |  |  |
|                | DQ4 → DQ5                                                                                                                                      | $DQ12 \rightarrow DQ13$ | $DQ20 \rightarrow tbd$               | $\text{DQ28} \rightarrow \text{tbd}$ |  |  |
|                | DQ5 → DQ4                                                                                                                                      | DQ13 → DQ12             | $DQ21 \rightarrow tbd$               | $\text{DQ29} \rightarrow \text{tbd}$ |  |  |
|                | DQ6 → DQ7                                                                                                                                      | $DQ14 \rightarrow DQ15$ | $DQ22 \rightarrow tbd$               | $\text{DQ30} \rightarrow \text{tbd}$ |  |  |
|                | DQ7 → DQ6                                                                                                                                      | $DQ15 \rightarrow DQ14$ | $\text{DQ23} \rightarrow \text{tbd}$ | $DQ31 \rightarrow tbd$               |  |  |
| 01<br>10<br>11 | Reserved                                                                                                                                       |                         |                                      |                                      |  |  |

The Nibble Map is coded in Table 84:

Table 84 — Nibble Map Encoding

| Nibble Map                          |                             |      |                                                                 |      |                                                       |
|-------------------------------------|-----------------------------|------|-----------------------------------------------------------------|------|-------------------------------------------------------|
| Nibble Bit<br>Order<br>at Connector | Bit Map Index<br>Bits 4 ~ 0 |      | Bit 5 = 0: Wired to Lower Nibble<br>Bit Order within SDRAM Byte |      | = 1: Wired to Upper Nibble<br>Order within SDRAM Byte |
|                                     | 00000                       | 0x00 | Bit Map not specified                                           | 0x20 | Bit Map not specified                                 |
|                                     | 00001                       | 0x01 | 0, 1, 2, 3                                                      | 0x21 | 4, 5, 6, 7                                            |
|                                     | 00010                       | 0x02 | 0, 1, 3, 2                                                      | 0x22 | 4, 5, 7, 6                                            |
| 0, 1, 2, 3                          | 00011                       | 0x03 | 0, 2, 1, 3                                                      | 0x23 | 4, 6, 5, 7                                            |
| (4, 5, 6, 7)                        | 00100                       | 0x04 | 0, 2, 3, 1                                                      | 0x24 | 4, 6, 7, 5                                            |
| •••                                 | 00101                       | 0x05 | 0, 3, 1, 2                                                      | 0x25 | 4, 7, 5, 6                                            |
|                                     | 00110                       | 0x06 | 0, 3, 2, 1                                                      | 0x26 | 4, 7, 6, 5                                            |
|                                     | 00111                       | 0x07 | 1, 0, 2, 3                                                      | 0x27 | 5, 4, 6, 7                                            |

| Nibble Map                          |                             |      |                                                                 |      |                                                       |
|-------------------------------------|-----------------------------|------|-----------------------------------------------------------------|------|-------------------------------------------------------|
| Nibble Bit<br>Order<br>at Connector | Bit Map Index<br>Bits 4 ~ 0 |      | Bit 5 = 0: Wired to Lower Nibble<br>Bit Order within SDRAM Byte |      | = 1: Wired to Upper Nibble<br>Order within SDRAM Byte |
|                                     | 01000                       | 80x0 | 1, 0, 3, 2                                                      | 0x28 | 5, 4, 7, 6                                            |
|                                     | 01001                       | 0x09 | 1, 2, 0, 3                                                      | 0x29 | 5, 6, 4, 7                                            |
|                                     | 01010                       | 0x0A | 1, 2, 3, 0                                                      | 0x2A | 5, 6, 7, 4                                            |
| 0, 1, 2, 3                          | 01011                       | 0x0B | 1, 3, 0, 2                                                      | 0x2B | 5, 7, 4, 6                                            |
| (4, 5, 6, 7)                        | 01100                       | 0x0C | 1, 3, 2, 0                                                      | 0x2C | 5, 7, 6, 4                                            |
|                                     | 01101                       | 0x0D | 2, 0, 1, 3                                                      | 0x2D | 6, 4, 5, 7                                            |
|                                     | 01110                       | 0x0E | 2, 0, 3, 1                                                      | 0x2E | 6, 4, 7, 5                                            |
|                                     | 01111                       | 0x0F | 2, 1, 0, 3                                                      | 0x2F | 6, 5, 4, 7                                            |
|                                     | 10000                       | 0x10 | 2, 1, 3, 0                                                      | 0x30 | 6, 5, 7, 4                                            |
|                                     | 10001                       | 0x11 | 2, 3, 0, 1                                                      | 0x31 | 6, 7, 4, 5                                            |
|                                     | 10010                       | 0x12 | 2, 3, 1, 0                                                      | 0x32 | 6, 7, 5, 4                                            |
| 0, 1, 2, 3                          | 10011                       | 0x13 | 3, 0, 1, 2                                                      | 0x33 | 7, 4, 5, 6                                            |
| (4, 5, 6, 7)                        | 10100                       | 0x14 | 3, 0, 2, 1                                                      | 0x34 | 7, 4, 6, 5                                            |
|                                     | 10101                       | 0x15 | 3, 1, 0, 2                                                      | 0x35 | 7, 5, 4, 6                                            |
| -                                   | 10110                       | 0x16 | 3, 1, 2, 0                                                      | 0x36 | 7, 5, 6, 4                                            |
|                                     | 10111                       | 0x17 | 3, 2, 0, 1                                                      | 0x37 | 7, 6, 4, 5                                            |
|                                     | 11000                       | 0x18 | 3, 2, 1, 0                                                      | 0x38 | 7, 6, 5, 4                                            |
|                                     | All other codes             |      | Reserved                                                        |      | Reserved                                              |

Table 84 — Nibble Map Encoding (Cont'd)

NOTE 1 1. Hex codes shown in this table are for bits 5~0 only and must be added to bits 7~6 (Package Rank Map bits) for the SPD byte entry

NOTE 2 2. Devices with x16 are treated as two separate x8 devices for CRC bit mapping within each byte. Similarly, x32 devices are treated as four separate x8 devices for CRC bit mapping within each byte.

#### **Example:** See Figure 3 and Table 85.



Figure 3 — Two Package Rank x8 Module (example only; may not represent a specific design)



Table 85 — Two Package Rank x8 Module (example only; may not represent a specific design)

#### 8.1.43 Bytes 78~116 (0x04E~0x074): Reserved, Base Configuration Section

Must be coded as 0x00

# 8.1.44 Byte 117 (0x075): Fine Offset for Minimum CAS to CAS Delay Time (t<sub>CCD\_L</sub>min), Same Bank Group

This byte modifies the calculation of SPD Byte 40 with a fine correction using FTB units. The value of  $t_{CCD\_L}$ min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 40, in Section 8.1.35. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

# 8.1.45 Byte 118 (0x076): Fine Offset for Minimum Activate to Activate Delay Time (t<sub>RRD\_L</sub>min), Same Bank Group

This byte modifies the calculation of SPD Byte 39 with a fine correction using FTB units. The value of  $t_{RRD\_L}$ min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 39, in Section 8.1.34. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

# 8.1.46 Byte 119 (0x077): Fine Offset for Minimum Activate to Activate Delay Time ( $t_{RRD\_S}$ min), Different Bank Group

This byte modifies the calculation of SPD Byte 38 (MTB units) with a fine correction using FTB units. The value of  $t_{RRD\_S}$ min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 38, in Section 8.1.33. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

#### 8.1.47 Byte 120 (0x078): Fine Offset for Minimum Active to Active/Refresh Delay Time (t<sub>RC</sub>min)

This byte modifies the calculation of SPD Bytes 27 and 29 (MTB units) with a fine correction using FTB units. The value of  $t_{RC}$ min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD bytes 27 and 29, in Sections 8.1.25 and 8.27. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

8.1 General Configuration Section: Bytes 0~127 (0x000~0x07F) (Cont'd)

#### 8.1.48 Byte 121 (0x079): Fine Offset for Minimum Row Precharge Delay Time (t<sub>RP</sub>min)

This byte modifies the calculation of SPD Byte 26 (MTB units) with a fine correction using FTB units. The value of  $t_{RP}$ min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 26, in Section 8.1.24. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

#### 8.1.49 Byte 122 (0x07A): Fine Offset for Minimum RAS to CAS Delay Time (t<sub>RCD</sub>min)

This byte modifies the calculation of SPD Byte 25 (MTB units) with a fine correction using FTB units. The value of  $t_{RCD}$ min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 25, in Section 8.1.23. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

## 8.1.50 Byte 123 (0x07B): Fine Offset for Minimum CAS Latency Time (t<sub>AA</sub>min)

This byte modifies the calculation of SPD Byte 24 (MTB units) with a fine correction using FTB units. The value of t<sub>AA</sub>min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 24, in Section 8.1.22. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

#### 8.1.51 Byte 124 (0x07C): Fine Offset for SDRAM Maximum Cycle Time (t<sub>CKAVG</sub>max)

This byte modifies the calculation of SPD Byte 19 (MTB units) with a fine correction using FTB units. The value of t<sub>CKAVG</sub>max comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 19, in Section 8.1.20. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

#### 8.1.52 Byte 125 (0x07D): Fine Offset for SDRAM Minimum Cycle Time (t<sub>CKAVG</sub>min)

This byte modifies the calculation of SPD Byte 18 (MTB units) with a fine correction using FTB units. The value of  $t_{CKAVG}$ min comes from the SDRAM data sheet. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

**Examples:** See SPD byte 19, in Section 8.1.20. For Two's Complement encoding, see Section 8.1.18.1, Relating the MTB and FTB.

# 8.1.53 Byte 126 (0x07E): Cyclical Redundancy Code (CRC) for Base Configuration Section, Least Significant Byte

Byte 127 (0x07F): Cyclical Redundancy Code (CRC) for Base Configuration Section, Most Significant Byte

This two-byte field contains the calculated CRC for bytes  $0\sim125$  ( $0x000\sim0x07D$ ) in the SPD. The following algorithm and data structures (shown in C) are to be followed in calculating and checking the code.

```
int Crc16 (char *ptr, int count)
{
   int crc, i;

   crc = 0;
   while (--count >= 0) {
      crc = crc ^ (int)*ptr++ << 8;
      for (i = 0; i < 8; ++i)
            if (crc & 0x8000)
            crc = crc << 1 ^ 0x1021;
      else
            crc = crc << 1;
   }
   return (crc & 0xFFFF);
}</pre>
```

```
char spdBytes[] = { SPD_byte_0, SPD_byte_1, ..., SPD_byte_N-1 };
int data16;

data16 = Crc16 (spdBytes, sizeof(spdBytes));
SPD_byte_126 = (char) (data16 & 0xFF);
SPD_byte_127 = (char) (data16 >> 8);
```

## 8.2 Module-Specific Section: Bytes 128~191 (0x080~0x0BF)

This section of the SPD contains bytes that are specific to DDR4 module families. Module Type Key Byte 3 is used as an index for the encoding of bytes 128~191. The content of bytes 128~191 are described in the separate sections, one for each memory module family.

- 9.1 UDIMMs
- 9.2 RDIMMs
- 9.3 LRDIMMs

#### 8.3 Hybrid Memory Architecture Specific Parameters: Bytes 192~255 (0x0C0~0x0FF)

This section of the SPD contains bytes that are specific to hybrid memory module families. Module Type Key Byte 3 bits 7~4 are used as an index for the encoding of bytes 192~255. The content of bytes 192~255 are described in separate sections, one for each hybrid module family.

• 10.1 - NVIMMs

#### 8.4 Extended Function Parameter Block: Bytes 256~319 (0x100~0x13F)

This section of the SPD contains zero or more blocks of extended function and interface protocol parameter sets for Hybrid memory modules. The content of bytes 256~319 are described in separate sections, one for each hybrid module function type.

- 11.1 Extended Function Parameter Block for Byte Addressable Energy Backed NVDIMM (BYTE-E)
- 11.2 Extended Function Parameter Block for Block Addressed NVDIMM (BLOCK)
- 11.3 Extended Function Parameter Block for Byte Addressable No Energy Backed NVDIMM (BYTE-NOE)

#### 8.5 Module Supplier's Data: Bytes 320~383 (0x140~0x17F)

# 8.5.1 Byte 320 (0x140): Module Manufacturer ID Code, First Byte Byte 321 (0x141): Module Manufacturer ID Code, Second Byte

This two-byte field, shown in Table 86, indicates the manufacturer of the module, encoded as follows: the first byte is the number of continuation bytes indicated in JEP-106; the second byte is the last non-zero byte of the manufacturer's ID code, again as indicated in JEP-106.

| Byte 321, Bits 7~0                         | Byte 320, Bit 7                   | Byte 320, Bits 6~0                                   |
|--------------------------------------------|-----------------------------------|------------------------------------------------------|
| Last non-zero byte,<br>Module Manufacturer | Odd Parity for Byte 320, bits 6~0 | Number of continuation codes,<br>Module Manufacturer |
| See JEP-106                                |                                   | See JEP-106                                          |

Table 86 — Bytes 320 and 321: Module Manufacturer ID Code

#### 8.5.1 Bytes 320 and 321: Module Manufacturer ID Code (Cont'd)

Examples: See Table 87.

Table 87 — Examples of Module Manufacturer ID Code

| JEP-106    |      | -106 | # continuation | SPD      |          |
|------------|------|------|----------------|----------|----------|
| Company    | Bank | Code | codes          | Byte 320 | Byte 321 |
| Fujitsu    | 1    | 04   | 0              | 0x80     | 0x04     |
| US Modular | 5    | A8   | 4              | 0x04     | 0xA8     |

#### 8.5.2 Byte 322 (0x142): Module Manufacturing Location

The module manufacturer includes an identifier that uniquely defines the manufacturing location of the memory module. While the SPD specification will not attempt to present a decode table for manufacturing sites, the individual manufacturer may keep track of manufacturing location and its appropriate decode represented in this byte.

#### 8.5.3 Bytes 323~324 (0x143~0x144): Module Manufacturing Date

The module manufacturer includes a date code for the module. The JEDEC definitions for bytes 323 and 324 are year and week respectively. These bytes must be represented in Binary Coded Decimal (BCD). For example, week 47 in year 2014 would be coded as 0x14 (0001 0100) in byte 323 and 0x47 (0100 0111) in byte 324.

#### 8.5.4 Bytes 325~328 (0x145~0x148): Module Serial Number

The supplier must include a unique serial number for the module. The supplier may use whatever decode method desired to maintain a unique serial number for each module.

One method of achieving this is by assigning a byte in the field from 325~328 as a tester ID byte and using the remaining bytes as a sequential serial number. Bytes 320~328 will then result in a nine-byte unique module identifier. Note that part number is not included in this identifier: the supplier may not give the same value for Bytes 320~328 to more than one DIMM even if the DIMMs have different part numbers.

#### 8.5.5 Bytes 329~348 (0x149~15C): Module Part Number

The manufacturer's part number is written in ASCII format within these bytes. Unused digits are coded as ASCII blanks (0x20).

#### 8.5.6 Bytes 349 (0x15D): Module Revision Code

This refers to the module revision code. While the SPD specification will not attempt to define the format for this information, the individual manufacturer may keep track of the revision code and its appropriate decode represented in this byte. This revision code refers to the manufacturer's assembly revision level and may be different than the raw card revision in SPD bytes 128 and 130.

# 8.5.7 Byte 350 (0x15E): DRAM Manufacturer ID Code, First Byte Byte 351 (0x15F): DRAM Manufacturer ID Code, Second Byte

This two-byte field, shown in Table 88, indicates the manufacturer of the DRAM on the module, encoded as follows: the first byte is the number of continuation bytes indicated in JEP-106; the second byte is the last non-zero byte of the manufacturer's ID code, again as indicated in JEP-106.

Table 88 — Bytes 350 and 351: DRAM Manufacturer ID Code

| Byte 351, Bits 7~0                       | Byte 350, Bit 7                   | Byte 350, Bits 6~0                                 |
|------------------------------------------|-----------------------------------|----------------------------------------------------|
| Last non-zero byte,<br>DRAM Manufacturer | Odd Parity for Byte 350, bits 6~0 | Number of continuation codes,<br>DRAM Manufacturer |
| See JEP-106                              |                                   | See JEP-106                                        |

**Example:** See bytes 320~321, in Section 3.5.1, for example manufacturer codes.

#### 8.5.8 Byte 352 (0x160): DRAM Stepping

This byte, shown in Table 89, defines the vendor die revision level (often called the "stepping") of the DRAMs on the module. This byte is optional. For modules without DRAM stepping information, this byte should be programmed to 0xFF.

**Table 89** — Byte **352** (0x160): DRAM Stepping

| Bits 7~0                                                                        |
|---------------------------------------------------------------------------------|
| DRAM Stepping                                                                   |
| Programmed in straight Hex format - no conversion needed. 00 - Valid 01 - Valid |
| <br>FE - Valid<br>FF - Undefined (No Stepping Number Provided)                  |

**Examples:** See Table 90.

Table 90 — Examples of DRAM Stepping

| Code | Meaning                           |  |
|------|-----------------------------------|--|
| 0x00 | Stepping 0                        |  |
| 0x01 | Stepping 1                        |  |
| 0x31 | Stepping 3.1                      |  |
| 0xA3 | Stepping A3                       |  |
| 0xB1 | Stepping B1                       |  |
| 0xFF | Stepping information not provided |  |

#### 8.5.9 Bytes 353~381 (0x161~0x17D): Manufacturer's Specific Data

The module manufacturer may include any additional information desired into the module within these locations.

#### 8.5.10 Byte 382~383 (0x17E~0x17F): Reserved

Must be coded as 0x00.

#### 8.6 ASCII Decode Matrix for SPDs

Table 91 is a subset of the full ASCII standard which is used for coding bytes in the Serial Presence Detect EEPROM that require ASCII characters:

Second Hex Digit in Pair **First Hex** 0 1 2 3 4 5 6 8 9 Α В С D Ε F Digit in Pair Blank 2 ) Space Dash Period 3 2 5 9 0 1 3 6 4 Α С Ε F G Η J Κ L Μ 0 5 Υ Ρ Q R S Т U ٧ W Х Ζ 6 i d f k 1 b С е h 0 7 t ٧ z

Table 91 — ASCII Decode Matrix for SPDs

#### 8.6 ASCII Decode Matrix for SPDs (Cont'd)

**Examples:** See Table 92.

0x20 = Blank Space

0x34 = '4'0x41 = 'A'

**Table 92 — SPD Bytes 329~348** 

| SPD Bytes 329~348                                     |  |  |  |  |
|-------------------------------------------------------|--|--|--|--|
| Manufacturer's PN Coded in ASCII                      |  |  |  |  |
| 13M32734BCD-260Y 31334D33323733344243442D323630592020 |  |  |  |  |

## 9 SPD Bytes Specific to DDR4 Module Families

# 9.1 Module Specific Bytes for Unbuffered Memory Module Types (Bytes 128~191, 0x080~0x0BF)

This section defines the encoding of SPD bytes 128~191 when Memory Technology Key Byte 2 contains the value 0x0C and Module Type Key Byte 3 contains any of the following:

- 0xH2, UDIMM
- 0xH3, SO-DIMM
- 0xH6, Mini-UDIMM
- 0xH9, 72b-SO-UDIMM
- 0xHC, 16b-SO-DIMM
- 0xHD, 32b-SO-DIMM
- where H refers to the hybrid memory architecture, if any present on the module

Table 93 is the SPD address map for the module specific section, bytes 128~255, of the SPD for Unbuffered Module Types.

Table 93 — Module Specific SPD Bytes for Unbuffered Module Types

| Byte Number                                                                        |             | Function Described                           | Notes |  |
|------------------------------------------------------------------------------------|-------------|----------------------------------------------|-------|--|
| 128                                                                                | 0x080       | Raw Card Extension, Module Nominal Height    |       |  |
| 129                                                                                | 0x081       | Module Maximum Thickness                     |       |  |
| 130                                                                                | 0x082       | Reference Raw Card Used                      |       |  |
| 131                                                                                | 0x083       | Address Mapping from Edge Connector to DRAM  |       |  |
| 132~191                                                                            | 0x084~0x0BF | Reserved Must be coded as 0x00               |       |  |
| 254                                                                                | 0x0FE       | CRC for SPD Block 1, Least Significant Byte  | 1     |  |
| 255                                                                                | 0x0FF       | CRC for SPD Block 1, Most Significant Byte 1 |       |  |
| NOTE 1 CRC in bytes 254~255 covers all of SPD Block 1, bytes 128~255 (0x080~0x0FF) |             |                                              |       |  |

#### 9.1.1 Byte 128 (0x080) (Unbuffered): Raw Card Extension, Module Nominal Height

The upper 3 bits of this byte, shown in Table 94, define extensions to the Raw Card Revision in Byte 130. The lower 5 bits of this byte define the nominal height (A dimension) in millimeters of the fully assembled module including heat spreaders or other added components. Refer to the relevant JEDEC JC-11 module outline (MO) documents for dimension definitions.

Bits 7~5 Bits 4~0 Module Nominal Height max, in mm **Raw Card Extension** (baseline height = 15 mm) 000 = raw card revisions 0 to 3; see byte 130 00000 = height ≤ 15 mm 001 = raw card revision 4 00001 = 15 < height ≤ 16 mm 010 = raw card revision 5 00010 = 16 < height ≤ 17 mm 011 = raw card revision 6 00011 = 17 < height ≤ 18 mm 100 = raw card revision 7 00100 = 18 < height ≤ 19 mm 101 = raw card revision 8 110 = raw card revision 9 01010 = 24 < height ≤ 25 mm 111 = raw card revision 10  $01011 = 25 < height \le 26 mm$  $01111 = 29 < height \le 30 mm$ 10000 = 30 < height ≤ 31 mm  $10001 = 31 < height \le 32 mm$ 11111 = 45 mm < height

Table 94 — Byte 128 (0x080) (Unbuffered): Raw Card Extension, Module Nominal Height

Examples: See Table 95.

Table 95 — Examples of Byte 128 (0x080

| Nominal Module Height | Coding, bits 4~0      | Meaning             |
|-----------------------|-----------------------|---------------------|
| mm                    | Binary                | mm                  |
| 18.75                 | 00100                 | 18 < height ≤ 19 mm |
| 25.40                 | 01011                 | 25 < height ≤ 26 mm |
| 30.00                 | 01111 29 < height ≤ 3 |                     |
| 30.25                 | 10000 30 < height ≤   |                     |
| 31.25                 | 10001                 | 30 < height ≤ 31 mm |

#### 9.1.2 Byte 129 (0x081) (Unbuffered): Module Maximum Thickness

This byte, shown in Table 96, defines the maximum thickness (E dimension) in millimeters of the fully assembled module including heat spreaders or other added components above the module circuit board surface. Thickness of the front of the module is calculated as the E1 dimension minus the PCB thickness. Thickness of the back of the module is calculated as the E dimension minus the E1 dimension, rounding up to the next integer. Refer to the relevant JEDEC JC-11 module outline (MO) documents for dimension definitions.

Table 96 — Byte 129 (0x081) (Unbuffered): Module Maximum Thickness

| Bits 7~4                                                                                                                                                                                                                                                                | Bits 3~0                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module Maximum Thickness max, Back, in mm (baseline thickness = 1 mm)                                                                                                                                                                                                   | Module Maximum Thickness max, Front, in mm (baseline thickness = 1 mm)                                                                                                                                                                                                  |
| $0000 = \text{thickness} \le 1 \text{ mm}$ $0001 = 1 < \text{thickness} \le 2 \text{ mm}$ $0010 = 2 < \text{thickness} \le 3 \text{ mm}$ $0011 = 3 < \text{thickness} \le 4 \text{ mm}$ $1110 = 14 < \text{thickness} \le 15 \text{ mm}$ $1111 = 15 < \text{thickness}$ | $0000 = \text{thickness} \le 1 \text{ mm}$ $0001 = 1 < \text{thickness} \le 2 \text{ mm}$ $0010 = 2 < \text{thickness} \le 3 \text{ mm}$ $0011 = 3 < \text{thickness} \le 4 \text{ mm}$ $1110 = 14 < \text{thickness} \le 15 \text{ mm}$ $1111 = 15 < \text{thickness}$ |
| Note: Thickness = E - E1                                                                                                                                                                                                                                                | Note: Thickness = E1 - PCB                                                                                                                                                                                                                                              |

9.1 Module Specific Bytes for Unbuffered Memory Module Types (Bytes 128~191, 0x080~0x0BF) (Cont'd)

#### 9.1.3 Byte 130 (0x082) (Unbuffered): Reference Raw Card Used

This byte, shown in Tables 97 and 98, indicates which JEDEC reference design raw card was used as the basis for the module assembly, if any. Bits  $4\sim0$  describe the raw card and bits  $6\sim5$  describe the revision level of that raw card. Special reference raw card indicator, ZZ, is used when no JEDEC standard raw card reference design was used as the basis for the module design. Preproduction modules should be encoded as revision 0 in bits  $6\sim5$ .

Table 97 — Byte 130 (0x082) (Unbuffered): Reference Raw Cards A through AL

| Bit 7                                | Bits 6~5                                                                                                                                                                                                     | Bits 4~0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Raw Card Extension         | Reference Raw Card Revision                                                                                                                                                                                  | Reference Raw Card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0 = Reference raw cards A through AL | Reference Raw Card Revision  00 = revision 0 01 = revision 1 10 = revision 2 11 = revision 3  See byte 128 for extensions beyond revision 3; these bits must be coded as 11 for all revisions greater than 3 | When bit 7 = 0,  00000 = Reference raw card A  00001 = Reference raw card B  00010 = Reference raw card C  00011 = Reference raw card D  00100 = Reference raw card E  00101 = Reference raw card F  00110 = Reference raw card F  00110 = Reference raw card G  00111 = Reference raw card H  01000 = Reference raw card H  01000 = Reference raw card L  01011 = Reference raw card K  01010 = Reference raw card M  01100 = Reference raw card N  01101 = Reference raw card R  01111 = Reference raw card R  01111 = Reference raw card T  10000 = Reference raw card U  10001 = Reference raw card W  10010 = Reference raw card W  10011 = Reference raw card AA  10101 = Reference raw card AB  10110 = Reference raw card AC  10111 = Reference raw card AF  11000 = Reference raw card AF  11010 = Reference raw card AF  11010 = Reference raw card AH  11101 = Reference raw card AK  11110 = Reference raw card AK  11110 = Reference raw card AK  11110 = Reference raw card AK  11111 = ZZ (no JEDEC reference raw |
|                                      |                                                                                                                                                                                                              | card design used)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bit 7                                 | Bits 6~5                                                                                                                                                                       | Bits 4~0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Raw Card Extension          | Reference Raw Card Revision                                                                                                                                                    | Reference Raw Card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1 = Reference raw cards AM through CB | 00 = revision 0 01 = revision 1 10 = revision 2 11 = revision 3 See byte 128 for extensions beyond revision 3; these bits must be coded as 11 for all revisions greater than 3 | When bit 7 = 1,  00000 = Reference raw card AM  00001 = Reference raw card AN  00010 = Reference raw card AP  00011 = Reference raw card AR  00100 = Reference raw card AT  00101 = Reference raw card AT  00101 = Reference raw card AV  00110 = Reference raw card AW  00110 = Reference raw card AW  01000 = Reference raw card AY  01001 = Reference raw card BA  01010 = Reference raw card BB  01011 = Reference raw card BC  01100 = Reference raw card BD  01101 = Reference raw card BD  01101 = Reference raw card BF  01111 = Reference raw card BF  01111 = Reference raw card BF  01000 = Reference raw card BH  10001 = Reference raw card BH  10010 = Reference raw card BK  10011 = Reference raw card BK  10011 = Reference raw card BK  10010 = Reference raw card BN  10110 = Reference raw card BN  10110 = Reference raw card BR  11000 = Reference raw card BR  11001 = Reference raw card BR  11001 = Reference raw card BR  11001 = Reference raw card BB  11101 = Reference raw card BW  11101 = Reference raw card CB  11111 = ZZ (no JEDEC reference raw card CB |

Table 98 — Byte 130 (0x082) (Unbuffered): Reference Raw Cards AM through CB

## 9.1.4 Byte 131 (0x083) (Unbuffered): Address Mapping from Edge Connector to DRAM

This byte, shown in Table 99, describes the connection of edge connector pins for address bits to the corresponding input pins of the DDR4 SDRAMs for rank 1 only; rank 0 is always assumed to use standard mapping. Only two connection types are supported, standard or mirrored, as described in the mapping table below. System software must compensate for this mapping when issuing mode register set commands to the ranks of DDR4 SDRAMs on this module.

Table 99 — Byte 131 (0x083) (Unbuffered): Address Mapping from Edge Connector to DRAM

| Bits 7~1                           | Bit 0                        |
|------------------------------------|------------------------------|
| Reserved                           | Rank 1 Mapping               |
| Reserved; must bo coded as 0000000 | 0 = standard<br>1 = mirrored |

#### 9.1.4 Byte 131 (0x083) (Unbuffered): Address Mapping from Edge Connector to DRAM (Cont'd)

The definition of standard and mirrored address connection mapping is detailed in Table 100; highlighted rows in the table indicate which signals change between mappings.

| Edge Connector<br>Pin | DRAM Pin,<br>Non-mirrored | DRAM Pin,<br>Mirrored |
|-----------------------|---------------------------|-----------------------|
| A0                    | A0                        | A0                    |
| A1                    | A1                        | A1                    |
| A2                    | A2                        | A2                    |
| A3                    | A3                        | A4                    |
| A4                    | A4                        | A3                    |
| A5                    | A5                        | A6                    |
| A6                    | A6                        | A5                    |
| A7                    | A7                        | A8                    |
| A8                    | A8                        | A7                    |
| A9                    | A9                        | A9                    |
| A10                   | A10                       | A10                   |
| A11                   | A11                       | A13                   |
| A13                   | A13                       | A11                   |
| A12                   | A12                       | A12                   |
| A14                   | A14                       | A14                   |
| A15                   | A15                       | A15                   |
| A16                   | A16                       | A16                   |
| A17                   | A17                       | A17                   |
| BA0                   | BA0                       | BA1                   |
| BA1                   | BA1                       | BA0                   |
| BG0                   | BG0                       | BG1                   |
| BG1                   | BG1                       | BG0                   |

Table 100 — Mirrored Address Connection Mapping

### 9.1.5 Bytes 132~191 (0x084~0x0BF) (Unbuffered):

Reserved – must be coded as 0x00

# 9.1.6 Byte 254 (0x0FE) (Unbuffered): Cyclical Redundancy Code (CRC) for SPD Block 1, Least Significant Byte Byte 255 (0x0FF) (Unbuffered): Cyclical Redundancy Code (CRC) for SPD Block 1, Most Significant Byte

This two-byte field contains the calculated CRC for bytes  $128\sim253$  ( $0x080\sim0x0FD$ ) in the SPD. See bytes  $126\sim127$ , Section 8.1.53, for a coding example.

# 9.2 Module Specific Bytes for Registered Memory Module Types (Bytes 128~191, 0x080~0x0BF)

This section defines the encoding of SPD bytes 128~191 when Memory Technology Key Byte 2 contains the value 0x0C and Module Type Key Byte 3 contains any of the following:

- 0xH1, RDIMM
- 0xH5, Mini-RDIMM
- 0xH8, 72b-SO-RDIMM
- where H refers to the hybrid memory architecture, if any present on the module

Table 101 provides the SPD address map for the module specific section, bytes 128~191, of the SPD for Registered Module Types.

| Byte I                                                                         | Number      | Function Described                                             | Notes |
|--------------------------------------------------------------------------------|-------------|----------------------------------------------------------------|-------|
| 128                                                                            | 0x080       | Raw Card Extension, Module Nominal Height                      |       |
| 129                                                                            | 0x081       | Module Maximum Thickness                                       |       |
| 130                                                                            | 0x082       | Reference Raw Card Used                                        |       |
| 131                                                                            | 0x083       | DIMM Attributes                                                |       |
| 132                                                                            | 0x084       | RDIMM Thermal Heat Spreader Solution                           |       |
| 133                                                                            | 0x085       | Register Manufacturer ID Code, Least Significant Byte          |       |
| 134                                                                            | 0x086       | Register Manufacturer ID Code, Most Significant Byte           |       |
| 135                                                                            | 0x087       | Register Revision Number                                       |       |
| 136                                                                            | 0x088       | Address Mapping from Register to DRAM                          |       |
| 137                                                                            | 0x89        | Register Output Drive Strength for Control and Command/Address |       |
| 138                                                                            | 0x8A        | Register Output Drive Strength for Clock                       |       |
| 139~191                                                                        | 0x089~0x0BF | Reserved must be coded as 0x00                                 |       |
| 254                                                                            | 0x0FE       | CRC for SPD Block 1, Least Significant Byte                    | 1     |
| 255                                                                            | 0x0FF       | CRC for SPD Block 1, Most Significant Byte                     | 1     |
| 1. CRC in bytes 254~255 covers all of SPD Block 1, bytes 128~255 (0x080~0x0FF) |             |                                                                |       |

Table 101 — Module Specific SPD Bytes for Registered Module Types

#### 9.2.1 Byte 128 (0x080) (Registered): Raw Card Extension, Module Nominal Height

The upper 3 bits of this byte, shown in Table 102, define extensions to the Raw Card Revision in Byte 130. The lower 5 bits of this byte define the nominal height (A dimension) in millimeters of the fully assembled module including heat spreaders or other added components. Refer to the relevant JEDEC JC-11 module outline (MO) documents for dimension definitions.

Table 102 — Byte 128 (0x080) (Registered): Raw Card Extension, Module Nominal Height

| Bits 7~5                                                                                                                                                                                                                             | Bits 4~0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Raw Card Extension                                                                                                                                                                                                                   | Module Nominal Height max, in mm<br>(baseline height = 15 mm)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 000 = raw card revisions 0 to 3; see byte 130 001 = raw card revision 4 010 = raw card revision 5 011 = raw card revision 6 100 = raw card revision 7 101 = raw card revision 8 110 = raw card revision 9 111 = raw card revision 10 | $\begin{array}{l} 00000 = \text{height} \leq 15 \text{ mm} \\ 00001 = 15 < \text{height} \leq 16 \text{ mm} \\ 00010 = 16 < \text{height} \leq 17 \text{ mm} \\ 00011 = 17 < \text{height} \leq 18 \text{ mm} \\ 00100 = 18 < \text{height} \leq 19 \text{ mm} \\ \dots \\ 01010 = 24 < \text{height} \leq 25 \text{ mm} \\ 01011 = 25 < \text{height} \leq 26 \text{ mm} \\ \dots \\ 01111 = 29 < \text{height} \leq 30 \text{ mm} \\ 10000 = 30 < \text{height} \leq 31 \text{ mm} \\ 10001 = 31 < \text{height} \leq 32 \text{ mm} \\ \dots \\ 11111 = 45 \text{ mm} < \text{height} \end{array}$ |

**Examples:** See Table 103.

| Nominal Module Height | Coding, bits 4~0 | Meaning             |
|-----------------------|------------------|---------------------|
| mm                    | Binary           | mm                  |
| 18.75                 | 00100            | 18 < height ≤ 19 mm |
| 25.40                 | 01011            | 25 < height ≤ 26 mm |
| 30.00                 | 01111            | 29 < height ≤ 30 mm |
| 30.25                 | 10000            | 30 < height ≤ 31 mm |
| 31.25                 | 10001            | 31 < height ≤ 32 mm |

Table 103 — Examples of Raw Card Extension, Module Nominal Height

#### 9.2.2 Byte 129 (0x081) (Registered): Module Maximum Thickness

This byte, shown in Table 104, defines the maximum thickness (E dimension) in millimeters of the fully assembled module including heat spreaders or other added components above the module circuit board surface, rounding up to the next integer. Thickness of the front of the module is calculated as the E1 dimension minus the PCB thickness. Thickness of the back of the module is calculated as the E dimension minus the E1 dimension. Refer to the relevant JEDEC JC-11 module outline (MO) documents for dimension definitions.

| Table 104 — Byte 129 (0x081) (Reg | istered): Module Maximum Thickness |
|-----------------------------------|------------------------------------|
|                                   |                                    |

| Bits 7~4                                                                                                                                                                                                                                                                | Bits 3~0                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module Maximum Thickness max, Back, in mm (baseline thickness = 1 mm)                                                                                                                                                                                                   | Module Maximum Thickness max, Front, in mm (baseline thickness = 1 mm)                                                                                                                                                                                                  |
| $0000 = \text{thickness} \le 1 \text{ mm}$ $0001 = 1 < \text{thickness} \le 2 \text{ mm}$ $0010 = 2 < \text{thickness} \le 3 \text{ mm}$ $0011 = 3 < \text{thickness} \le 4 \text{ mm}$ $1110 = 14 < \text{thickness} \le 15 \text{ mm}$ $1111 = 15 < \text{thickness}$ | $0000 = \text{thickness} \le 1 \text{ mm}$ $0001 = 1 < \text{thickness} \le 2 \text{ mm}$ $0010 = 2 < \text{thickness} \le 3 \text{ mm}$ $0011 = 3 < \text{thickness} \le 4 \text{ mm}$ $1110 = 14 < \text{thickness} \le 15 \text{ mm}$ $1111 = 15 < \text{thickness}$ |
| NOTE Thickness = E - E1                                                                                                                                                                                                                                                 | NOTE Thickness = E1 - PCB                                                                                                                                                                                                                                               |

#### 9.2.3 Byte 130 (0x082) (Registered): Reference Raw Card Used

This byte, shown in Tables 105 and 106, indicates which JEDEC reference design raw card was used as the basis for the module assembly, if any. Bits 4~0 describe the raw card and bits 6~5 describe the revision level of that raw card. Special raw card indicator, ZZ, is used when no JEDEC standard raw card was used as the basis for the design. Pre-production modules should be encoded as revision 0 in bits 6~5.

Table 105 — Byte 130 (0x082) (Registered): Reference Raw Cards A through AL

| Bit 7                                | Bits 6~5                                                                                                                                                                       | Bits 4~0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Raw Card Extension         | Reference Raw Card Revision                                                                                                                                                    | Reference Raw Card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0 = Reference raw cards A through AL | 00 = revision 0 01 = revision 1 10 = revision 2 11 = revision 3 See byte 128 for extensions beyond revision 3; these bits must be coded as 11 for all revisions greater than 3 | When bit 7 = 0,  00000 = Reference raw card A  00001 = Reference raw card B  00010 = Reference raw card C  00011 = Reference raw card D  00100 = Reference raw card E  00101 = Reference raw card F  00110 = Reference raw card F  00110 = Reference raw card G  00111 = Reference raw card H  01000 = Reference raw card H  01001 = Reference raw card K  01010 = Reference raw card K  01010 = Reference raw card N  01100 = Reference raw card N  01101 = Reference raw card R  01111 = Reference raw card R  01111 = Reference raw card R  01111 = Reference raw card W  10001 = Reference raw card W  10001 = Reference raw card V  10000 = Reference raw card W  10010 = Reference raw card W  10011 = Reference raw card AA  10101 = Reference raw card AA  10101 = Reference raw card AB  10110 = Reference raw card AC  10111 = Reference raw card AF  11000 = Reference raw card AF  11001 = Reference raw card AF  11010 = Reference raw card AH  11101 = Reference raw card AK  11110 = Reference raw card AK  11111 = ZZ (no JEDEC reference raw card design used) |

| Bit 7                                 | Bits 6~5                                                                                                                                                                       | Bits 4~0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Raw Card Extension          | Reference Raw Card Revision                                                                                                                                                    | Reference Raw Card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1 = Reference raw cards AM through CB | 00 = revision 0 01 = revision 1 10 = revision 2 11 = revision 3 See byte 128 for extensions beyond revision 3; these bits must be coded as 11 for all revisions greater than 3 | When bit 7 = 1,  00000 = Reference raw card AM  00001 = Reference raw card AN  00010 = Reference raw card AP  00011 = Reference raw card AP  00011 = Reference raw card AR  00100 = Reference raw card AT  00101 = Reference raw card AU  00110 = Reference raw card AV  00111 = Reference raw card AW  01000 = Reference raw card AY  01001 = Reference raw card BA  01010 = Reference raw card BB  01011 = Reference raw card BC  01100 = Reference raw card BC  01100 = Reference raw card BE  01110 = Reference raw card BF  01111 = Reference raw card BF  01111 = Reference raw card BF  01000 = Reference raw card BH  10001 = Reference raw card BH  10010 = Reference raw card BK  10010 = Reference raw card BK  10011 = Reference raw card BK  10010 = Reference raw card BN  10110 = Reference raw card BN  10110 = Reference raw card BR  10100 = Reference raw card BR  11000 = Reference raw card BR  11001 = Reference raw card BR  11001 = Reference raw card BW  11011 = Reference raw card BW  11010 = Reference raw card BW  11011 = Reference raw card CA  11110 = Reference raw card CB  11111 = ZZ (no JEDEC reference raw card design used) |

Table 106 — Byte 130 (0x082) (Registered): Reference Raw Cards AM through CB

#### 9.2.4 Byte 131 (0x083) (Registered): DIMM Attributes

This byte, shown in Table 107, indicates number of registers used on a module, and the register type. Further it indicates number of rows of DRAM packages (monolithic, DDP or other stacked) parallel to edge connector (independent of DRAM orientation) on each side of the printed circuit board.

Bits 7~4 Bits 3~2 Bits 1~0 # of rows of DRAMs on # of Registers used on **Register Type** RDIMM **RDIMM** 0000 = DDR4RCD01 00 = Undefined 00 = Undefined 0001 = DDR4RCD02 01 = 1 row01 = 1 register All other values reserved 10 = 2 rows10 = 2 registers 11 = 4 rows11 = 4 registers

Table 107 — Byte 131 (0x083) (Registered): DIMM Attributes

#### 9.2.5 Byte 132 (0x084) (Registered): RDIMM Thermal Heat Spreader Solution

This byte, shown in Table 108, describes the module's supported thermal heat spreader solution.

Table 108 — Byte 132 (0x084) (Registered): RDIMM Thermal Heat Spreader Solution

| Bit 7                                                                                                                           | Bits 6~0                                          |
|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| Heat Spreader Solution                                                                                                          | Heat Spreader Thermal Characteristics             |
| 0 = Heat spreader solution is not incorporated onto this assembly 1 = Heat spreader solution is incorporated onto this assembly | 0 = Undefined<br>All other settings to be defined |

# 9.2.6 Byte 133 (0x085) (Registered): Register Manufacturer ID Code, First Byte Byte 134 (0x086) (Registered): Register Manufacturer ID Code, Second Byte

This two-byte field, shown in Table 109, indicates the manufacturer of the register used on the module, encoded as follows: the first byte is the number of continuation bytes indicated in JEP-106; the second byte is the last non-zero byte of the manufacturer's ID code, again as indicated in JEP-106. These bytes are optional. For modules without the Register Manufacturer ID Code information both bytes should be programmed to 0x00.

Table 109 — Bytes 133 and 134, Register Manufacturer ID Code

| Byte 134, Bits 7~0                           | Byte 133, Bit 7                      | Byte 133 Bits 6~0                                      |
|----------------------------------------------|--------------------------------------|--------------------------------------------------------|
| Last non-zero byte,<br>Register Manufacturer | Odd parity<br>for Byte 133, bits 6~0 | Number of continuation codes,<br>Register Manufacturer |
| See JEP-106                                  |                                      | See JEP-106                                            |

**Example:** See SPD bytes 320~321, Section 8.5.1, for example manufacturer codes.

#### 9.2.7 Byte 135 (0x087) (Registered): Register Revision Number

This byte, shown in Table 110, defines the vendor die revision level of the registering clock driver component. This byte is optional. For modules without the Register Revision Number information, this byte should be programmed to 0xFF. See byte 131, Section 9.2.4, for the register type.

Table 110 — Byte 135 (0x087) (Registered): Register Revision Number

| Bits 7~0                                                                        |
|---------------------------------------------------------------------------------|
| Register Revision Number                                                        |
| Programmed in straight Hex format - no conversion needed. 00 - Valid 01 - Valid |
| <br>FE - Valid<br>FF - Undefined (No Revision Number Provided)                  |

**Examples:** See Table 111.

Table 111 — Examples of Register Revision Number

| Code | Meaning                           |  |
|------|-----------------------------------|--|
| 0x00 | Revision 0                        |  |
| 0x01 | Revision 1                        |  |
| 0x31 | Revision 3.1                      |  |
| 0xA3 | Revision A3                       |  |
| 0xB1 | Revision B1                       |  |
| 0xFF | Revision information not supplied |  |

#### 9.2.8 Byte 136 (0x088) (Registered): Address Mapping from Register to DRAM

This byte, shown in Table 112, describes the connection of register output pins for address bits to the corresponding input pins of the DDR4 SDRAMs for rank 1 and rank 3 only; rank 0 and rank 2 are always assumed to use standard mapping. Only two connection types are supported, standard or mirrored, as described in the mapping table below. System software must compensate for this mapping when issuing mode register set commands to the ranks of DDR4 SDRAMs on this module.

Table 112 — Byte 136 (0x088) (Registered): Address Mapping from Register to DRAM

| Bits 7~1                           | Bit 0                        |  |
|------------------------------------|------------------------------|--|
| Reserved                           | Rank 1 Mapping               |  |
| Reserved; must be coded as 0000000 | 0 = standard<br>1 = mirrored |  |

The definition of standard and mirrored address connection mapping is detailed in Table 113; highlighted rows in the table indicate which signals change between mappings.

Table 113 — Standard and Mirrored Address Connection Mapping

| Edge Connector<br>Pin | DRAM Pin,<br>Non-mirrored | DRAM Pin,<br>Mirrored |
|-----------------------|---------------------------|-----------------------|
| A0                    | A0                        | A0                    |
| A1                    | A1                        | A1                    |
| A2                    | A2                        | A2                    |
| A3                    | A3                        | A4                    |
| A4                    | A4                        | A3                    |
| A5                    | A5                        | A6                    |
| A6                    | A6                        | A5                    |
| A7                    | A7                        | A8                    |
| A8                    | A8                        | A7                    |
| A9                    | A9                        | A9                    |
| A10                   | A10                       | A10                   |
| A11                   | A11                       | A13                   |
| A13                   | A13                       | A11                   |
| A12                   | A12                       | A12                   |
| A14                   | A14                       | A14                   |
| A15                   | A15                       | A15                   |
| A16                   | A16                       | A16                   |
| A17                   | A17                       | A17                   |
| BA0                   | BA0                       | BA1                   |
| BA1                   | BA1                       | BA0                   |
| BG0                   | BG0                       | BG1                   |
| BG1                   | BG1                       | BG0                   |

## 9.2.9 Byte 137 (0x089) (Registered): Register Output Drive Strength for Control and Command/ Address

This byte, shown in Table 114, defines the drive strength for the registering clock driver outputs for control and address/command signals.

Table 114 — Byte 137 (0x089) (Registered): Register Output Drive Strength for Control and Command/Address

| Chip Select                                                       |       | Command       | d/Address ODT    |                                         | DT                | CKE                                     |                   |  |
|-------------------------------------------------------------------|-------|---------------|------------------|-----------------------------------------|-------------------|-----------------------------------------|-------------------|--|
| Bit 7                                                             | Bit 6 | Bit 5         | Bit 4            | Bit 3                                   | Bit 2             | Bit 1                                   | Bit 0             |  |
| 00 = Light Drive<br>01 = Moderate Drive                           |       | <u> </u>      |                  | 00 = Light Drive<br>01 = Moderate Drive |                   | 00 = Light Drive<br>01 = Moderate Drive |                   |  |
| 10 = Strong Drive                                                 |       | 10 = Strong [ | 0 = Strong Drive |                                         | 10 = Strong Drive |                                         | 10 = Strong Drive |  |
| 11 = Very Strong Drive                                            |       | 11 = Very Str | ong Drive        | 11 = Very Strong Drive                  |                   | 11 = Very Strong Drive                  |                   |  |
| THE VERY CHOING BINVE THE VERY CHOING BINVE THE VERY CHOING BINVE |       |               |                  |                                         |                   |                                         |                   |  |

NOTE Standard values for drive strength are defined in the DDR4 Registered DIMM Reference Design Specification for JEDEC standard module reference designs.

#### 9.2.10 Byte 138 (0x08A) (Registered): Register Output Drive Strength for Clock

This byte, shown in Table 115, defines the drive strength for the registering clock driver outputs.

Table 115 — Byte 138 (0x08A) (Registered): Register Output Drive Strength for Clock

| Reserved                           | RCD Output Slew<br>Rate Control | Reserved    |       | Y1,                                                                     | Y3          | Y0,                                                              | Y2               |
|------------------------------------|---------------------------------|-------------|-------|-------------------------------------------------------------------------|-------------|------------------------------------------------------------------|------------------|
| Bit 7                              | Bit 6                           | Bit 5       | Bit 4 | Bit 3                                                                   | Bit 2       | Bit 1                                                            | Bit 0            |
| Reserved;<br>must be coded<br>as 0 |                                 | coded as 00 |       | 00 = Light Drive<br>01 = Moderate<br>10 = Strong Dri<br>11 = Very Stror | Drive<br>ve | 00 = Light Dri<br>01 = Moderat<br>10 = Strong I<br>11 = Very Str | e Drive<br>Drive |

NOTE Standard values for drive strength are defined in the DDR4 Registered DIMM Reference Design Specification for JEDEC standard module reference designs.

## 9.2.11 Bytes 139~191 (0x08B~0x0BF) (Registered):

Reserved — must be coded as 0x00

# 9.2.12 Byte 254 (0x0FE) (Registered): Cyclical Redundancy Code (CRC) for SPD Block 1, Least Significant Byte

Byte 255 (0x0FF) (Registered): Cyclical Redundancy Code (CRC) for SPD Block 1, Most Significant Byte

This two-byte field contains the calculated CRC for bytes 128~253 (0x080~0x0FD) in the SPD. See bytes 126~127, Section 8.1.53, for a coding example.

# 9.3 Module Specific Bytes for Load Reduced Memory Module Types (Bytes 128~191, 0x080~0x0BF)

This section defines the encoding of SPD bytes 128~191 when Memory Technology Key Byte 2 contains the value 0x0C and Module Type Key Byte 3 contains any of the following:

- 0xH4, LRDIMM
- where H refers to the hybrid memory architecture, if any present on the module

Table 116 provides the SPD address map for the module specific section, bytes 128~255, of the SPD for Load Reduced Module Types.

Table 116 — Module Specific SPD Bytes for Load Reduced Module Types

| Byte Number |       | Function Described                        | Notes |
|-------------|-------|-------------------------------------------|-------|
| 128         | 0x080 | Raw Card Extension, Module Nominal Height |       |
| 129         | 0x081 | Module Maximum Thickness                  |       |
| 130         | 0x082 | Reference Raw Card Used                   |       |
| 131         | 0x083 | DIMM Module Attributes                    |       |

Table 116 — Module Specific SPD Bytes for Load Reduced Module Types (Cont'd)

| Byte Number |                                                      | Function Described                                                                               | Notes |
|-------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------|
| 132         | 0x084                                                | LRDIMM Thermal Heat Spreader Solution                                                            |       |
| 133         | 0x085                                                | Register and Data Buffer Manufacturer ID Code, Least Significant Byte                            |       |
| 134         | 0x086                                                | Register and Data Buffer Manufacturer ID Code, Most Significant Byte                             |       |
| 135         | 0x087                                                | Register Revision Number                                                                         |       |
| 136         | 0x088                                                | Address Mapping from Register to DRAM                                                            |       |
| 137         | 0x089                                                | Register Output Drive Strength for Control and Command/Address                                   |       |
| 138         | 0x08A                                                | Register Output Drive Strength for Clock and Data Buffer Control                                 |       |
| 139         | 0x08B                                                | Data Buffer Revision Number                                                                      |       |
| 140         | 0x08C                                                | DRAM VrefDQ for Package Rank 0                                                                   |       |
| 141         | 0x08D                                                | DRAM VrefDQ for Package Rank 1                                                                   |       |
| 142         | 0x08E                                                | DRAM VrefDQ for Package Rank 2                                                                   |       |
| 143         | 0x08F                                                | DRAM VrefDQ for Package Rank 3                                                                   |       |
| 144         | 0x090                                                | Data Buffer VrefDQ for DRAM Interface                                                            |       |
| 145         | 0x091                                                | Data Buffer MDQ Drive Strength and RTT for data rate ≤ 1866                                      |       |
| 146         | 0x092                                                | Data Buffer MDQ Drive Strength and RTT for 1866 < data rate ≤ 2400                               |       |
| 147         | 0x093                                                | Data Buffer MDQ Drive Strength and RTT for 2400 < data rate ≤ 3200                               |       |
| 148         | 0x094                                                | DRAM Drive Strength (for data rates ≤ 1866, 1866 < data rate <2400, and 2400 < data rate ≤ 3200) |       |
| 149         | 0x095                                                | DRAM ODT (RTT_WR, RTT_NOM) for data rate ≤ 1866                                                  |       |
| 150         | 0x096                                                | DRAM ODT (RTT_WR, RTT_NOM) for 1866 < data rate ≤ 2400                                           |       |
| 151         | 0x097                                                | DRAM ODT (RTT_WR, RTT_NOM) for 2400 < data rate ≤ 3200                                           |       |
| 152         | 0x098                                                | DRAM ODT (RTT_PARK) for data rate ≤ 1866                                                         |       |
| 153         | 0x099                                                | DRAM ODT (RTT_PARK) for 1866 < data rate ≤ 2400                                                  |       |
| 154         | 0x09A                                                | DRAM ODT (RTT_PARK) for 2400 < data rate ≤ 3200                                                  |       |
| 155         | 0x09B                                                | Data buffer VrefDQ for DRAM interface range                                                      |       |
| 156         | 0x09C                                                | Data buffer DQ Decision Feedback Equalization (DFE)                                              |       |
| 157~191     | 0x09D~0x0BF                                          | Reserved must be coded as 0x00                                                                   |       |
| 254         | 0x0FE                                                | CRC for SPD Block 1, Least Significant Byte                                                      | 1     |
| 255         | 255 0x0FF CRC for SPD Block 1, Most Significant Byte |                                                                                                  |       |
| 1. CRC in   | bytes 254~255 co                                     | vers all of SPD Block 1, bytes 128~255 (0x080~0x0FF)                                             |       |

#### 9.3.1 Byte 128 (0x080) (Load Reduced): Raw Card Extension, Module Nominal Height

The upper 3 bits of this byte, shown in Table 117, define extensions to the Raw Card Revision in Byte 130. The lower 5 bits of this byte define the nominal height (A dimension) in millimeters of the fully assembled module including heat spreaders or other added components. Refer to the relevant JEDEC JC-11 module outline (MO309A) documents for dimension definitions.

Bits 7 ~ 5 Bits 4 ~ 0 Module Nominal Height max, in mm **Raw Card Extension** (baseline height = 15 mm) 000 = raw card revisions 0 to 3; see byte 130 00000 = height ≤ 15 mm 001 = raw card revision 4 00001 = 15 < height ≤ 16 mm 010 = raw card revision 5 00010 = 16 < height ≤ 17 mm 011 = raw card revision 6  $00011 = 17 < height \le 18 mm$ 100 = raw card revision 7 00100 = 18 < height ≤ 19 mm 101 = raw card revision 8 110 = raw card revision 9 01010 = 24 < height ≤ 25 mm 111 = raw card revision 10 01011 = 25 < height ≤ 26 mm 01111 = 29 < height ≤ 30 mm 10000 = 30 < height ≤ 31 mm 11111 = 45 mm < height

Table 117 — Byte 128 (0x080) (Load Reduced): Raw Card Extension, Module Nominal Height

Examples: See Table 118.

Table 118 — Examples of Raw Card Extension, Module Nominal Height

| Nominal Module Height | Coding, bits 4 ~ 0 | Meaning             |
|-----------------------|--------------------|---------------------|
| mm                    | Binary             | mm                  |
| 18.75                 | 00100              | 18 < height ≤ 19 mm |
| 25.40                 | 01011              | 25 < height ≤ 26 mm |
| 30.00                 | 01111              | 29 < height ≤ 30 mm |
| 30.25                 | 10000              | 30 < height ≤ 31 mm |
| 31.25                 | 10001              | 31 < height ≤ 32 mm |

#### 9.3.2 Byte 129 (0x081) (Load Reduced): Module Maximum Thickness

This byte, shown in Table 119, defines the maximum thickness (E dimension) in millimeters of the fully assembled module including heat spreaders or other added components above the module circuit board surface, rounding up to the next integer. Thickness of the front of the module is calculated as the E1 dimension minus the PCB thickness. Thickness of the back of the module is calculated as the E dimension minus the E1 dimension. Refer to the relevant JEDEC JC-11 module outline (MO) documents for dimension definitions.

Table 119 — Byte 129 (0x081) (Load Reduced): Module Maximum Thickness

| Bits 7 ~ 4                                                                                                                                                                                                                                                                   | Bits 3 ~ 0                                                                                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Module Maximum Thickness max, Back, in mm (baseline thickness = 1 mm)                                                                                                                                                                                                        | Module Maximum Thickness max, Front, in mm (baseline thickness = 1 mm)                                                                                                                                                                                                  |
| $0000 = \text{thickness} \leq 1 \text{ mm}$ $0001 = 1 < \text{thickness} \leq 2 \text{ mm}$ $0010 = 2 < \text{thickness} \leq 3 \text{ mm}$ $0011 = 3 < \text{thickness} \leq 4 \text{ mm}$ $1110 = 14 < \text{thickness} \leq 15 \text{ mm}$ $1111 = 15 < \text{thickness}$ | $0000 = \text{thickness} \le 1 \text{ mm}$ $0001 = 1 < \text{thickness} \le 2 \text{ mm}$ $0010 = 2 < \text{thickness} \le 3 \text{ mm}$ $0011 = 3 < \text{thickness} \le 4 \text{ mm}$ $1110 = 14 < \text{thickness} \le 15 \text{ mm}$ $1111 = 15 < \text{thickness}$ |
| NOTE Thickness = E - E1                                                                                                                                                                                                                                                      | NOTE 1 Thickness = E1 - PCB                                                                                                                                                                                                                                             |

#### 9.3.3 Byte 130 (0x082) (Load Reduced): Reference Raw Card Used

This byte, shown in Tables 120 and 121, indicates which JEDEC reference design raw card was used as the basis for the module assembly, if any. Bits 4~0 describe the raw card and bits 6~5 describe the revision level of that raw card. Special raw card indicator, ZZ, is used when no JEDEC standard raw card was used as the basis for the design. Pre-production modules should be encoded as revision 0 in bits 6~5.

Table 120 — Byte 130 (0x082) (Load Reduced): Reference Raw Cards A through AL

| Bit 7                                | Bits 6 ~ 5                                                                                                                                                                     | Bits 4 ~ 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Raw Card Extension         | Reference Raw Card Revision                                                                                                                                                    | Reference Raw Card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0 = Reference raw cards A through AL | 00 = revision 0 01 = revision 1 10 = revision 2 11 = revision 3 See byte 128 for extensions beyond revision 3; these bits must be coded as 11 for all revisions greater than 3 | When bit 7 = 0,  00000 = Reference raw card A  00001 = Reference raw card B  00010 = Reference raw card C  00011 = Reference raw card D  00100 = Reference raw card E  00101 = Reference raw card F  00110 = Reference raw card F  00110 = Reference raw card G  00111 = Reference raw card H  01000 = Reference raw card J  01001 = Reference raw card K  01010 = Reference raw card K  01010 = Reference raw card M  01100 = Reference raw card N  01101 = Reference raw card N  01101 = Reference raw card R  01111 = Reference raw card T  10000 = Reference raw card T  10000 = Reference raw card V  10010 = Reference raw card W  10011 = Reference raw card W  10011 = Reference raw card AA  10101 = Reference raw card AA  10101 = Reference raw card AA  10101 = Reference raw card AA  10110 = Reference raw card AB  10110 = Reference raw card AB  10110 = Reference raw card AF  11001 = Reference raw card AF  11001 = Reference raw card AF  11001 = Reference raw card AH  11101 = Reference raw card AH  11101 = Reference raw card AK  11110 = Reference raw card AK  11110 = Reference raw card AK  11110 = Reference raw card AK |
|                                      |                                                                                                                                                                                | card design used)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

Bits 6 ~ 5 Bits 4 ~ 0 Bit 7 Reference Raw Card Extension Reference Raw Card Revision Reference Raw Card 1 = Reference raw cards AM through When bit 7 = 1, 00 = revision 001 = revision 100000 = Reference raw card AM 10 = revision 2 00001 = Reference raw card AN 11 = revision 3 00010 = Reference raw card AP 00011 = Reference raw card AR See byte 128 for extensions 00100 = Reference raw card AT beyond revision 3; these bits 00101 = Reference raw card AU must be coded as 11 for all 00110 = Reference raw card AV revisions greater than 3 00111 = Reference raw card AW 01000 = Reference raw card AY 01001 = Reference raw card BA 01010 = Reference raw card BB 01011 = Reference raw card BC 01100 = Reference raw card BD 01101 = Reference raw card BE 01110 = Reference raw card BF 01111 = Reference raw card BG 10000 = Reference raw card BH 10001 = Reference raw card BJ 10010 = Reference raw card BK 10011 = Reference raw card BL 10100 = Reference raw card BM 10101 = Reference raw card BN 10110 = Reference raw card BP 10111 = Reference raw card BR 11000 = Reference raw card BT 11001 = Reference raw card BU 11010 = Reference raw card BV 11011 = Reference raw card BW 11100 = Reference raw card BY 11101 = Reference raw card CA 11110 = Reference raw card CB 11111 = ZZ (no JEDEC reference raw card design used)

Table 121 — Byte 130 (0x082) (Load Reduced): Reference Raw Cards AM through CB

#### 9.3.4 Byte 131 (0x083) (Load Reduced): DIMM Attributes

This byte, shown in Table 122, indicates number of registers used on a module, and the type of the registers and data buffers. Further it indicates number of rows of DRAM packages (monolithic, DDP or 3D stacked) parallel to edge connector (independent of DRAM orientation) on each side of the printed circuit board.

| Bits 7~4                                                                                   | Bits 3~2                                                     | Bits 1~0                                                            |  |  |
|--------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------|--|--|
| Register and Data Buffer Types                                                             | # of rows of DRAMs on LRDIMM # of Registe on LRDI            |                                                                     |  |  |
| 0000 = DDR4RCD01 and DDR4DB01<br>0001 = DDR4RCD02 and DDR4DB02<br>All other codes reserved | 00 = Undefined<br>01 = 1 row<br>10 = 2 rows<br>11 = Reserved | 00 = Undefined<br>01 = 1 register<br>10 = Reserved<br>11 = Reserved |  |  |

Table 122 — Byte 131 (0x083) (Load Reduced): DIMM Attributes

#### 9.3.5 Byte 132 (0x084) (Load Reduced): LRDIMM Thermal Heat Spreader Solution

This byte, shown in Table 123, describes if the module assembly incorporates a heat spreader.

Table 123 — Byte 132 (0x084) (Load Reduced): LRDIMM Thermal Heat Spreader Solution

| Bit 7                                                                                                                           | Bit 6~0                               |
|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| Heat Spreader                                                                                                                   | Heat Spreader Thermal Characteristics |
| 0 = Heat spreader solution is not incorporated onto this assembly 1 = Heat spreader solution is incorporated onto this assembly | Undefined; must be coded as 0000000   |

# 9.3.6 Byte 133 (0x085) (Load Reduced): Register and Data Buffer Manufacturer ID Code, First Byte Byte 134 (0x086) (Load Reduced): Register and Data Buffer Manufacturer ID Code, Second Byte

This two-byte field, shown in Table 124, indicates the manufacturer of the memory buffer used on the module, encoded as follows: the first byte is the number of continuation bytes indicated in JEP-106; the second byte is the last non-zero byte of the manufacturer's ID code, again as indicated in JEP-106.

Table 124 — Bytes 133 and 133, (Load Reduced): Register and Data Buffer Manufacturer ID Code

| Byte 134, Bits 7 ~ 0                                                               | Byte 133, Bit 7 | Byte 133 Bits 6 ~ 0                                         |
|------------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------|
| Last non-zero byte, Odd parity Memory Buffer Manufacturer for Byte 133, bits 6 ~ 0 |                 | Number of continuation codes,<br>Memory Buffer Manufacturer |
| See JEP-106                                                                        |                 | See JEP-106                                                 |

**Example:** See SPD byte 320~321, Section 8.5.1, for example manufacturer codes.

#### 9.3.7 Byte 135 (0x087) (Load Reduced): Register Revision Number

This byte, shown in Table 125, defines the vendor die revision level of the registering clock driver component. See byte 131, Section 9.3.4, for the register type.

Table 125 — Byte 135 (0x087) (Load Reduced): Register Revision Number

| Bits 7 ~ 0                                                                      |
|---------------------------------------------------------------------------------|
| Register Revision Number                                                        |
| Programmed in straight Hex format - no conversion needed. 00 - Valid 01 - Valid |
| <br>FE - Valid<br>FF - Undefined                                                |

Examples: See Table 126

Table 126 — Examples of (Load Reduced) Register Revision Number

| Code | Meaning      |
|------|--------------|
| 0x00 | Revision 0   |
| 0x01 | Revision 1   |
| 0x31 | Revision 3.1 |
| 0xA3 | Revision A3  |
| 0xB1 | Revision B1  |

#### 9.3.8 Byte 136 (0x088) (Load Reduced): Address Mapping from Register to DRAM

This byte, shown in Table 127, describes the connection of register output pins for address bits to the corresponding input pins of the DDR4 SDRAMs for odd ranks only; even ranks are always assumed to use standard mapping. Only two connection types are

currently supported, all rank non-mirrored or odd ranks mirrored, as described in the mapping table below. System software must compensate for this mapping when issuing mode register set commands to the ranks of DDR4 SDRAMs on this module.

Table 127 — Byte 136 (0x088) (Load Reduced): Address Mapping from Register to DRAM

| Bits 7 ~ 1                         | Bits 0                       |
|------------------------------------|------------------------------|
| Reserved                           | Odd Rank Mapping             |
| Reserved; must be coded as 0000000 | 0 = standard<br>1 = mirrored |

The definition of standard and mirrored address connection mapping is detailed in Table 128; highlighted rows in the table indicate which signals change between mappings.

Table 128 — Standard and Mirrored Address Connection Mapping

| Edge Connector<br>Pin | DRAM Pin,<br>Non-mirrored | DRAM Pin,<br>Mirrored |
|-----------------------|---------------------------|-----------------------|
| A0                    | A0                        | A0                    |
| A1                    | A1                        | A1                    |
| A2                    | A2                        | A2                    |
| A3                    | A3                        | A4                    |
| A4                    | A4                        | A3                    |
| A5                    | A5                        | A6                    |
| A6                    | A6                        | A5                    |
| A7                    | A7                        | A8                    |
| A8                    | A8                        | A7                    |
| A9                    | A9                        | A9                    |
| A10                   | A10                       | A10                   |
| A11                   | A11                       | A13                   |
| A13                   | A13                       | A11                   |
| A12                   | A12                       | A12                   |
| A14                   | A14                       | A14                   |
| A15                   | A15                       | A15                   |
| A16                   | A16                       | A16                   |
| A17                   | A17                       | A17                   |
| BA0                   | BA0                       | BA1                   |
| BA1                   | BA1                       | BA0                   |
| BG0                   | BG0                       | BG1                   |
| BG1                   | BG1                       | BG0                   |

## 9.3.9 Byte 137 (0x089) (Load Reduced): Register Output Drive Strength for Control and Command/

This byte, shown in Table 129, defines the drive strength for control and command/address outputs of the registering clock driver component.

Table 129 — Byte 137 (0x089) (Load Reduced): Register Output Drive Strength for Control and Command/Address

| Chip Select                                                          |               | Command/Address                                           |                    | ODT CKE                                                                |              | CKE                                                                     |             |
|----------------------------------------------------------------------|---------------|-----------------------------------------------------------|--------------------|------------------------------------------------------------------------|--------------|-------------------------------------------------------------------------|-------------|
| Bit 7                                                                | Bit 6         | Bit 5                                                     | Bit 4              | Bit 3 Bit 2                                                            |              | Bit 1                                                                   | Bit 0       |
| 00 = Light Driv<br>01 = Moderate<br>10 = Strong Dr<br>11 = Very Stro | Drive<br>rive | 00 = Light D<br>01 = Modera<br>10 = Strong<br>11 = Very S | ate Drive<br>Drive | 00 = Light Drive<br>01 = Moderate<br>10 = Strong Dr<br>11 = Very Stron | Drive<br>ive | 00 = Light Drive<br>01 = Moderate<br>10 = Strong Dri<br>11 = Very Stror | Drive<br>ve |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Specification for JEDEC standard module reference designs.

## 9.3.10 Byte 138 (0x08A) (Load Reduced): Register Output Drive Strength for Clock and Data Buffer Control

This byte, shown in Table 130, defines the drive strength for clock outputs and data buffer control outputs of the registering clock driver component.

Table 130 — Byte 138 (0x08A) (Load Reduced): Register Output Drive Strength for Clock and Data Buffer Control

| Reserved | RCD Output<br>Slew Rate<br>Control | вск   | BCOM, BODT,<br>BCKE                       | Y1, Y3                                   |       | Y0, Y2                                                           |                  |
|----------|------------------------------------|-------|-------------------------------------------|------------------------------------------|-------|------------------------------------------------------------------|------------------|
| Bit 7    | Bit 6                              | Bit 5 | Bit 4                                     | Bit 3                                    | Bit 2 | Bit 1                                                            | Bit 0            |
|          | supported                          |       | 0 = Moderate<br>Drive<br>1 = Strong Drive | 01 = Moderate Drive<br>10 = Strong Drive |       | 00 = Light Dri<br>01 = Moderat<br>10 = Strong D<br>11 = Very Str | e Drive<br>Irive |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

#### 9.3.11 Byte 139 (0x08B) (Load Reduced): Data Buffer Revision Number

This byte, shown in Table 131, defines the vendor die revision level of the data buffer component. See byte 131 for the data buffer type.

Table 131 — Byte 139 (0x08B) (Load Reduced): Data Buffer Revision Number

| Bits 7 ~ 0                                                                      |  |
|---------------------------------------------------------------------------------|--|
| Data Buffer Revision Number                                                     |  |
| Programmed in straight Hex format - no conversion needed. 00 - Valid 01 - Valid |  |
| <br>FE - Valid<br>FF - Undefined                                                |  |

Examples: See Table 132.

Table 132 — Examples of Data Buffer Revision Number

| Code | Meaning      |
|------|--------------|
| 0x00 | Revision 0   |
| 0x01 | Revision 1   |
| 0x31 | Revision 3.1 |
| 0xA3 | Revision A3  |
| 0xB1 | Revision B1  |

#### 9.3.12 Byte 140 (0x08C) (Load Reduced): DRAM VrefDQ for Package Rank 0

This byte, shown in Table 133, defines the VrefDQ value for the package rank 0 DRAMs.

Table 133 — Byte 140 (0x08C) (Load Reduced): DRAM VrefDQ for Package Rank 0

| Rese         | erved | DRAM VrefDQ for package rank 0 DRAMs                               |                                     |  |  |  |  |  |  |
|--------------|-------|--------------------------------------------------------------------|-------------------------------------|--|--|--|--|--|--|
| Bit 7        | Bit 6 | Bit 5                                                              | Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 |  |  |  |  |  |  |
| Reserved; mu |       | Encoding matches MR6 A5:A0 encoding in the JESD79-4 specification. |                                     |  |  |  |  |  |  |

NOTE 1 Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs

NOTE 2 See Byte 155, Section 9.3.27, for Range encoding

#### 9.3.13 Byte 141 (0x08D) (Load Reduced): DRAM VrefDQ for Package Rank 1

This byte, shown in Table 134, defines the VrefDQ value for the package rank 1 DRAMs.

Table 134 — Byte 141 (0x08D) (Load Reduced): DRAM VrefDQ for Package Rank 1

| Reserved                              |                     | DRAM VrefDQ for package rank 1 DRAMs                               |       |       |       |       |       |  |  |
|---------------------------------------|---------------------|--------------------------------------------------------------------|-------|-------|-------|-------|-------|--|--|
| Bit 7                                 | Bit 6               | Bit 5                                                              | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
| · · · · · · · · · · · · · · · · · · · | st be coded as<br>0 | Encoding matches MR6 A5:A0 encoding in the JESD79-4 specification. |       |       |       |       |       |  |  |

NOTE 1 Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs

NOTE 2 See Byte 155, Section 9.3.27, for Range encoding

#### 9.3.14 Byte 142 (0x08E) (Load Reduced): DRAM VrefDQ for Package Rank 2

This byte, shown in Table 135, defines the VrefDQ value for the package rank 2 DRAMs.

Table 135 — Byte 142 (0x08E) (Load Reduced): DRAM VrefDQ for Package Rank 2

| Reserved                      |       | DRAM VrefDQ for package rank 2 DRAMs                               |       |       |       |       |       |  |  |
|-------------------------------|-------|--------------------------------------------------------------------|-------|-------|-------|-------|-------|--|--|
| Bit 7                         | Bit 6 | Bit 5                                                              | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
| Reserved; must be coded as 00 |       | Encoding matches MR6 A5:A0 encoding in the JESD79-4 specification. |       |       |       |       |       |  |  |

NOTE 1 Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs

NOTE 2 See Byte 155, Section 9.3.27, for Range encoding

#### 9.3.15 Byte 143 (0x08F) (Load Reduced): DRAM VrefDQ for Package Rank 3

This byte, shown in Table 136, defines the VrefDQ value for the package rank 3 DRAMs.

Table 136 — Byte 143 (0x08F) (Load Reduced): DRAM VrefDQ for Package Rank 3

| Reserved     |       | DRAM VrefDQ for package rank 3 DRAMs                               |       |       |       |       |       |  |  |
|--------------|-------|--------------------------------------------------------------------|-------|-------|-------|-------|-------|--|--|
| Bit 7        | Bit 6 | Bit 5                                                              | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
| Reserved; mu |       | Encoding matches MR6 A5:A0 encoding in the JESD79-4 specification. |       |       |       |       |       |  |  |

NOTE 1 Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs

NOTE 2 See Byte 155, Section 9.3.27, for Range encoding

#### 9.3.16 Byte 144 (0x090) (Load Reduced): Data Buffer VrefDQ for DRAM Interface

This byte, shown in Table 137, defines the DRAM interface VrefDQ value for the data buffer component.

Table 137 — Byte 144 (0x090) (Load Reduced): Data Buffer VrefDQ for DRAM Interface

| Data Buffer VrefDQ for DRAM Interface                                                                   |                                                 |  |  |  |                  |               |             |  |  |  |
|---------------------------------------------------------------------------------------------------------|-------------------------------------------------|--|--|--|------------------|---------------|-------------|--|--|--|
| Bit 7                                                                                                   | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 |  |  |  |                  |               |             |  |  |  |
| For encoding see definition of F5BC6x (DRAM Interface VREF Control word) in the DDR4DB01 specification. |                                                 |  |  |  |                  |               |             |  |  |  |
| NOTE 1 Stand<br>reference desig                                                                         | ns                                              |  |  |  | esign Annexes fo | or JEDEC stan | dard module |  |  |  |

#### 9.3.17 Byte 145 (0x091) (Load Reduced): Data Buffer MDQ Drive Strength and RTT for data rate ≤ 1866

This byte, shown in Table 138, defines the drive strength for MDQ/MDQS outputs and the Read RTT termination strength of the data buffer component.

Table 138 — Byte 145 (0x091) (Load Reduced): Data Buffer MDQ Drive Strength and RTT for data rate ≤ 1866

| Data Buffer MDQ Drive Strength and RTT |                           |       |       |                                              |                                                                                                                                             |                                                    |       |  |  |
|----------------------------------------|---------------------------|-------|-------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-------|--|--|
| DRAM Interface MDQ Drive Strength      |                           |       |       | DRAM Interface MDQ Read Termination Strength |                                                                                                                                             |                                                    |       |  |  |
| Bit 7                                  | Bit 6                     | Bit 5 | Bit 4 | Bit 3                                        | Bit 2                                                                                                                                       | Bit 1                                              | Bit 0 |  |  |
| Reserved;<br>must be coded<br>as 0     | $000 = RZQ/6 (40 \Omega)$ |       |       | Reserved;<br>must be coded<br>as 0           | 000 = Disabled<br>001 = RZQ/4 (6<br>010 = RZQ/2 (1<br>011 = RZQ/6 (4<br>100 = RZQ (24<br>101 = RZQ/5 (4<br>110 = RZQ/3 (8<br>111 = RZQ/7 (3 | 50 Ω)<br>20 Ω)<br>50 Ω)<br>50 Ω)<br>68 Ω)<br>60 Ω) |       |  |  |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

# 9.3.18 Byte 146 (0x092) (Load Reduced): Data Buffer MDQ Drive Strength and RTT for 1866 < data rate ≤ 2400

This byte, shown in Table 139, defines the drive strength for MDQ/MDQS outputs and the Read RTT termination strength of the data buffer component.

Table 139 — Byte 146 (0x092) (Load Reduced): Data Buffer MDQ Drive Strength and RTT for  $1866 < data \ rate \le 2400$ 

|                                    |                                                                                                                                              | Data Bi                                 | Iller MDQ L | rive Strength an | ukii                                                                                                                                        |                                                    |          |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------|
| DRAI                               | DRAM Interface MDQ Drive Strength                                                                                                            |                                         |             |                  | rface MDQ Rea                                                                                                                               | d Termination                                      | Strength |
| Bit 7                              | Bit 6                                                                                                                                        | Bit 5                                   | Bit 4       | Bit 3            | Bit 2                                                                                                                                       | Bit 1                                              | Bit 0    |
| Reserved;<br>must be coded<br>as 0 | 000 = RZQ/6 (4<br>001 = RZQ/7 (3<br>010 = RZQ/5 (4<br>011 = Reserved<br>100 = Reserved<br>101 = RZQ/4 (6<br>110 = Reserved<br>111 = Reserved | 34 Ω)<br>18 Ω)<br>d<br>d<br>d<br>(00 Ω) |             | must be coded    | 000 = Disabled<br>001 = RZQ/4 (6<br>010 = RZQ/2 (1<br>011 = RZQ/6 (4<br>100 = RZQ (24<br>101 = RZQ/5 (4<br>110 = RZQ/3 (8<br>111 = RZQ/7 (3 | 50 Ω)<br>120 Ω)<br>40 Ω)<br>0 Ω)<br>48 Ω)<br>30 Ω) |          |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

# 9.3.19 Byte 147 (0x093) (Load Reduced): Data Buffer MDQ Drive Strength and RTT for 2400 < data rate ≤ 3200

This byte, shown in Table 140, defines the drive strength for MDQ/MDQS outputs and the Read RTT termination strength of the data buffer component.

Table 140 — Byte 147 (0x093) (Load Reduced): Data Buffer MDQ Drive Strength and RTT for  $2400 < \text{data rate} \le 3200$ 

|                                    |                                                                                                                                              | Data Bu                        | uffer MDQ D | rive Strength an                   | d RTT                                                                                                                                       |                                                       |          |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|----------|
| DRAM Interface MDQ Drive Strength  |                                                                                                                                              |                                |             | DRAM Inter                         | rface MDQ Rea                                                                                                                               | d Termination                                         | Strength |
| Bit 7                              | Bit 6                                                                                                                                        | Bit 5                          | Bit 4       | Bit 3                              | Bit 2                                                                                                                                       | Bit 1                                                 | Bit 0    |
| Reserved;<br>must be coded<br>as 0 | 000 = RZQ/6 (4<br>001 = RZQ/7 (3<br>010 = RZQ/5 (4<br>011 = Reserved<br>100 = Reserved<br>101 = RZQ/4 (6<br>110 = Reserved<br>111 = Reserved | 4 Ω)<br>8 Ω)<br>i<br>i<br>0 Ω) |             | Reserved;<br>must be coded<br>as 0 | 000 = Disabled<br>001 = RZQ/6 (6<br>010 = RZQ/2 (1<br>011 = RZQ/4 (4<br>100 = RZQ (24<br>101 = RZQ/5 (4<br>110 = RZQ/3 (8<br>111 = RZQ/7 (3 | 50 Ω)<br>(20 Ω)<br>(40 Ω)<br>(0 Ω)<br>(8 Ω)<br>(80 Ω) |          |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

9.3 Module Specific Bytes for Load Reduced Memory Module Types (Bytes 128~191, 0x080~0x0BF) (Cont'd)

# 9.3.20 Byte 148 (0x094) (Load Reduced): DRAM Drive Strength (for data rates $\leq$ 1866, 1866 < data rate $\leq$ 2400, and 2400 < data rate $\leq$ 3200)

This byte, shown in Table 141, defines the output buffer drive strength for the DRAMs.

Table 141 — Byte 148 (0x094) (Load Reduced): DRAM Drive Strength (for data rates  $\leq$  1866, 1866 < data rate  $\leq$  2400, and 2400 < data rate  $\leq$  3200)

|                               | DRAM Drive Strength |                         |       |                                        |       |                                        |       |  |  |
|-------------------------------|---------------------|-------------------------|-------|----------------------------------------|-------|----------------------------------------|-------|--|--|
| Reserved                      |                     | 2400 < Data rate ≤ 3200 |       | 1866 < Data rate ≤ 2400                |       | Data rate ≤ 1866                       |       |  |  |
| Bit 7                         | Bit 6               | Bit 5                   | Bit 4 | Bit 3                                  | Bit 2 | Bit 1                                  | Bit 0 |  |  |
| Reserved; must be coded as 00 |                     | 01 = RZQ/5 (48 Ω)       |       | 00 = RZQ/7 (34 Ω)<br>01 = RZQ/5 (48 Ω) |       | 00 = RZQ/7 (34 Ω)<br>01 = RZQ/5 (48 Ω) |       |  |  |
|                               |                     |                         |       | 10 = Reserved<br>11 = Reserved         |       | 10 = Reserved<br>11 = Reserved         |       |  |  |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

### 9.3.21 Byte 149 (0x095) (Load Reduced): DRAM ODT (RTT\_WR and RTT\_NOM) for data rate ≤ 1866

This byte, shown in Table 142, defines the ODT termination strength for the DRAMs.

Table 142 — Byte 149 (0x095) (Load Reduced): DRAM ODT (RTT WR and RTT NOM) for data rate ≤ 1866

| DRAM ODT Strength |                     |                                                                                                                                    |                                                           |       |  |                                                                                                                         |                                                           |       |  |
|-------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-------|--|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-------|--|
| Rese              | erved               |                                                                                                                                    | RTT_WR                                                    |       |  |                                                                                                                         | RTT_NOM                                                   |       |  |
| Bit 7             | Bit 6               | Bit 5                                                                                                                              | Bit 4                                                     | Bit 3 |  | Bit 2                                                                                                                   | Bit 1                                                     | Bit 0 |  |
|                   | st be coded as<br>0 | 000 = Dynami<br>001 = RZQ/2  <br>010 = RZQ (2<br>011 = Hi-Impe<br>100 = RZQ/3  <br>101 = Reserve<br>110 = Reserve<br>111 = Reserve | $(120 \ \Omega)$ $40 \ \Omega)$ edance $(80 \ \Omega)$ ed | Ů,    |  | 000 = Disable<br>001 = RZQ/4<br>010 = RZQ/2<br>011 = RZQ/6<br>100 = RZQ (2<br>101 = RZQ/5<br>110 = RZQ/3<br>111 = RZQ/7 | (60 Ω)<br>(120 Ω)<br>(40 Ω)<br>(40 Ω)<br>(48 Ω)<br>(80 Ω) |       |  |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

# 9.3.22 Byte 150 (0x096) (Load Reduced): DRAM ODT (RTT\_WR and RTT\_NOM) for 1866 < data rate < 2400

This byte, shown in Table 143, defines the ODT termination strength for the DRAMs.

reference designs.

Table 143 — Byte 150 (0x096) (Load Reduced): DRAM ODT (RTT\_WR and RTT\_NOM) for  $1866 < \text{data rate} \le 2400$ 

|       |                      |                                                                                                                                | DRAM OD                                                        | T Strength |                                                                                                                         |                                                           |       |
|-------|----------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-------|
| Res   | erved                |                                                                                                                                | RTT_WR                                                         |            |                                                                                                                         | RTT_NOM                                                   |       |
| Bit 7 | Bit 6                | Bit 5                                                                                                                          | Bit 4                                                          | Bit 3      | Bit 2                                                                                                                   | Bit 1                                                     | Bit 0 |
|       | st be coded as<br>00 | 000 = Dynami<br>001 = RZQ/2<br>010 = RZQ (2<br>011 = Hi-Impe<br>100 = RZQ/3<br>101 = Reserve<br>110 = Reserve<br>111 = Reserve | $(120\Omega)$<br>$40~\Omega)$<br>edance<br>$(80~\Omega)$<br>ed |            | 000 = Disable<br>001 = RZQ/4<br>010 = RZQ/2<br>011 = RZQ/6<br>100 = RZQ (2<br>101 = RZQ/5<br>110 = RZQ/3<br>111 = RZQ/7 | (60 Ω)<br>(120 Ω)<br>(40 Ω)<br>240 Ω)<br>(48 Ω)<br>(80 Ω) |       |

# 9.3.23 Byte 151 (0x097) (Load Reduced): DRAM ODT (RTT\_WR and RTT\_NOM) for 2400 < data rate < 3200

This byte, shown in Table 144, defines the ODT termination strength for the DRAMs.

Table 144 — Byte 151 (0x097) (Load Reduced): DRAM ODT (RTT\_WR and RTT\_NOM) for  $2400 < \text{data rate} \le 3200$ 

|       |                 |                                                                                                                           | DRAW OD                                               | T Strength |                                                                                                                         |                                                          |       |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-------|
| Res   | erved           |                                                                                                                           | RTT_WR                                                |            |                                                                                                                         | RTT_NOM                                                  |       |
| Bit 7 | Bit 6           | Bit 5                                                                                                                     | Bit 4                                                 | Bit 3      | Bit 2                                                                                                                   | Bit 1                                                    | Bit 0 |
| -     | ast be coded as | 000 = Dynam<br>001 = RZQ/2<br>010 = RZQ (2<br>011 = Hi-Imp<br>100 = RZQ/3<br>101 = Reserv<br>110 = Reserv<br>111 = Reserv | $(120\Omega)$ $(240~\Omega)$ edance $(80~\Omega)$ red |            | 000 = Disable<br>001 = RZQ/4<br>010 = RZQ/6<br>011 = RZQ/6<br>100 = RZQ (2<br>101 = RZQ/5<br>110 = RZQ/3<br>111 = RZQ/7 | (60 Ω)<br>(120 Ω)<br>(40 Ω)<br>40 Ω)<br>(48 Ω)<br>(80 Ω) |       |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

## 9.3.24 Byte 152 (0x098) (Load Reduced): DRAM ODT (RTT\_PARK) for data rate ≤ 1866

This byte, shown in Table 145, defines the ODT termination strength for the DRAMs.

Table 145 — Byte 152 (0x098) (Load Reduced): DRAM ODT (RTT\_PARK) for data rate ≤ 1866

|              |                |                           | DRAM OD            | T Strength |                            |               |             |
|--------------|----------------|---------------------------|--------------------|------------|----------------------------|---------------|-------------|
| Rese         | erved          | RTT_PAI                   | RK, Package R      | anks 2 & 3 | RTT_PAR                    | RK, Package F | Ranks 0 & 1 |
| Bit 7        | Bit 6          | Bit 5                     | Bit 4              | Bit 3      | Bit 2                      | Bit 1         | Bit 0       |
| Reserved; mu | st be coded as | 000 = Disabled            |                    |            | 000 = Disabled             |               |             |
| 00           |                | $001 = RZQ/4 (60 \Omega)$ |                    |            | 001 = RZQ/4 (60 Ω)         |               |             |
|              |                | 010 = RZQ/2               | $(120 \Omega)$     |            | $010 = RZQ/2 (120 \Omega)$ |               |             |
|              |                | 011 = RZQ/6               | 011 = RZQ/6 (40 Ω) |            |                            | (40 Ω)        |             |
|              |                | 100 = RZQ (2              | 240 Ω)             |            | 100 = RZQ (2               | 40 Ω)         |             |
|              |                | 101 = RZQ/5               | (48 Ω)             |            | 101 = RZQ/5                | (48 Ω)        |             |
|              |                | 110 = RZQ/3               | (80 Ω)             |            | 110 = RZQ/3                | (80 Ω)        |             |
|              |                | 111 = RZQ/7               | (34 Ω)             |            | 111 = RZQ/7                | (34 Ω)        |             |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

9.3 Module Specific Bytes for Load Reduced Memory Module Types (Bytes 128~191, 0x080~0x0BF) (Cont'd)

# 9.3.25 Byte 153 (0x099) (Load Reduced): DRAM ODT (RTT\_PARK) for 1866 < data rate ≤ 2400 This byte, shown in Table 146, defines the ODT termination strength for the DRAMs.

Table 146 — Byte 153 (0x099) (Load Reduced): DRAM ODT (RTT PARK) for 1866 < data rate  $\leq$  2400

|              |                |                            | DRAM OD       | T Strength |                            |                    |             |  |
|--------------|----------------|----------------------------|---------------|------------|----------------------------|--------------------|-------------|--|
| Rese         | erved          | RTT_PAI                    | RK, Package R | anks 2 & 3 | RTT_PAF                    | RK, Package F      | Ranks 0 & 1 |  |
| Bit 7        | Bit 6          | Bit 5                      | Bit 4         | Bit 3      | Bit 2                      | Bit 1              | Bit 0       |  |
| Reserved; mu | st be coded as | 000 = Disable              | ed            |            | 000 = Disabled             |                    |             |  |
| 00           |                | $001 = RZQ/4 (60 \Omega)$  |               |            | 001 = RZQ/4                | 001 = RZQ/4 (60 Ω) |             |  |
|              |                | $010 = RZQ/2 (120 \Omega)$ |               |            | $010 = RZQ/2 (120 \Omega)$ |                    |             |  |
|              |                | 011 = RZQ/6                | $(40 \Omega)$ |            | 011 = RZQ/6                | $(40 \Omega)$      |             |  |
|              |                | 100 = RZQ (2               | 240 Ω)        |            | 100 = RZQ (2               | 240 Ω)             |             |  |
|              |                | 101 = RZQ/5                | (48 Ω)        |            | 101 = RZQ/5                | (48 Ω)             |             |  |
|              |                | 110 = RZQ/3                | (80 Ω)        |            | 110 = RZQ/3                | (80 Ω)             |             |  |
|              |                | 111 = RZQ/7 (34 $\Omega$ ) |               |            | 111 = RZQ/7 (34 $\Omega$ ) |                    |             |  |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

# 9.3.26 Byte 154 (0x09A) (Load Reduced): DRAM ODT (RTT\_PARK) for 2400 < data rate < 3200

This byte, shown in Table 147, defines the ODT termination strength for the DRAMs.

Table 147 — Byte 154 (0x09A) (Load Reduced): DRAM ODT (RTT PARK) for 2400 < data rate  $\leq$  3200

|              |                |                               | DRAM OF                    | OT Strength |                            |                     |             |  |
|--------------|----------------|-------------------------------|----------------------------|-------------|----------------------------|---------------------|-------------|--|
| Res          | erved          | RTT_PARK, Package Ranks 2 & 3 |                            |             | RTT_PAF                    | RK, Package F       | Ranks 0 & 1 |  |
| Bit 7        | Bit 6          | Bit 5                         | Bit 4                      | Bit 3       | Bit 2                      | Bit 1               | Bit 0       |  |
| Reserved; mu | st be coded as | 000 = Disable                 | ed                         | •           | 000 = Disable              | ed                  |             |  |
| (            | 00             |                               |                            |             | 001 = RZQ/4                | (60 Ω)              |             |  |
|              |                |                               | $010 = RZQ/2 (120 \Omega)$ |             |                            | 010 = RZQ/2 (120 Ω) |             |  |
|              |                | 011 = RZQ/6                   | (40 Ω)                     |             | 011 = RZQ/6                | (40 Ω)              |             |  |
|              |                | 100 = RZQ (2                  | 240 Ω)                     |             | 100 = RZQ (2               | 240 Ω)              |             |  |
|              |                | 101 = RZQ/5                   | (48 Ω)                     |             | 101 = RZQ/5                | (48 Ω)              |             |  |
|              |                | 110 = RZQ/3                   | (80 Ω)                     |             | 110 = RZQ/3                | (80 Ω)              |             |  |
|              |                | 111 = RZQ/7                   | ,                          |             | 111 = RZQ/7 (34 $\Omega$ ) |                     |             |  |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs.

### 9.3.27 Byte 155 (0x09B) (Load Reduced): Data Buffer VrefDQ for DRAM Interface Range

This byte, shown in Table 148, defines the DRAM interface VrefDQ Range for the Data Buffer component.

Table 148 — Byte 155 (0x09B) (Load Reduced): Data Buffer VrefDQ for DRAM Interface Range

| Reserved                             | Data Buffer<br>VrefDQ for<br>DRAM Interface |                            | VrefDQ Range fo            | r DRAM interface           |                            |
|--------------------------------------|---------------------------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
|                                      | Data Buffer                                 | Rank 3                     | Rank 2                     | Rank 1                     | Rank 0                     |
| Bit 7~5                              | Bit 4                                       | Bit 3                      | Bit 2                      | Bit 1                      | Bit 0                      |
| Reserved, must be programmed to 000. | 0 = Range 1<br>1 = Range 2                  | 0 = Range 1<br>1 = Range 2 | 0 = Range 1<br>1 = Range 2 | 0 = Range 1<br>1 = Range 2 | 0 = Range 1<br>1 = Range 2 |

NOTE Standard values are defined in the DDR4 LRDIMM Reference Design Annexes for JEDEC standard module reference designs and DDR4DBx specifications.

#### 9.3.28 Byte 156 (0x09C) (Load Reduced): Data Buffer DQ Decision Feedback Equalization (DFE)

This byte, shown in Table 149, defines the DFE capabilities of the LRDIMM data buffer.

Table 149 — Byte 156(0x09C) (Load Reduced): Data Buffer DQ Decision Feedback Equalization (DFE)

| Data Buffer DQ DFE                      |                                    |                                    |  |  |  |  |
|-----------------------------------------|------------------------------------|------------------------------------|--|--|--|--|
| Reserved                                | Data Buffer DFE                    | Data Buffer Gain Adjustment        |  |  |  |  |
| Bits 7~2                                | Bit 1                              | Bit 0                              |  |  |  |  |
| Reserved; must be programmed to 000000  | 0 = not supported<br>1 = supported | 0 = not supported<br>1 = supported |  |  |  |  |
| NOTE See Data Buffer supplier's data sh | eet for details.                   |                                    |  |  |  |  |

#### 9.3.29 Bytes 157~191 (0x09D~0x0BF) (Load Reduced):

Reserved – must be coded as 0x00

# 9.3.30 Bytes 254 (0x0FE) (Load Reduced): Cyclical Redundancy Code (CRC) for SPD Block 1, Least Significant Byte

Bytes 255 (0x0FF) (Load Reduced): Cyclical Redundancy Code (CRC) for SPD Block 1, Most Significant Byte

This two-byte field contains the calculated CRC for bytes  $128\sim253$  ( $0x080\sim0x0FD$ ) in the SPD. See bytes  $126\sim127$ , Section 8.1.53, for coding example.

# 10 SPD Bytes Specific to Hybrid Memory Architecture Specific Parameters

### 10.1 Non-Volatile (NVDIMM-N) Hybrid Memory Parameters: Bytes 192~253 (0x0C0~0x1FD)

This section defines the encoding of SPD bytes 192~255 when Module Type Key Byte 3 contains the following:

- 0x9M, NVDIMM
- where M refers to the base memory architecture

NVDIMM types defined at this time are:

NVDIMM-N
Persistent DRAM using NAND flash
NVDIMM-F
NAND Flash accessed as a block oriented device
NVDIMM-H
NAND Flash accessed as a block oriented device
NVDIMM-P
Combined persistent DRAM and block accessed NAND Flash

Table 150 provides the SPD address map for the hybrid module specific section, bytes 192~255, of the SPD for Non-Volatile (NVDIMM) Module Types. Note that most NVDIMM types will also have extended function parameters in block 2, bytes 256~319, specific to each type.

Table 150 — Non-Volatile (NVDIMM-N) Hybrid Memory Parameters

| Byt | e Number | Function Described                                                           | Notes |
|-----|----------|------------------------------------------------------------------------------|-------|
| 192 | 0x0C0    | Module Product Identifier, First Byte                                        |       |
| 193 | 0x0C1    | Module Product Identifier, Second Byte                                       |       |
| 194 | 0x0C2    | Non-Volatile Memory Subsystem Controller Manufacturer's ID Code, First Byte  |       |
| 195 | 0x0C3    | Non-Volatile Memory Subsystem Controller Manufacturer's ID Code, Second Byte |       |
| 196 | 0x0C4    | Non-Volatile Memory Subsystem Controller Product Identifier, First Byte      |       |
| 197 | 0x0C5    | Non-Volatile Memory Subsystem Controller Product Identifier, Second Byte     |       |

| Byte Number                                                                           |             | Function Described                                     |  |  |
|---------------------------------------------------------------------------------------|-------------|--------------------------------------------------------|--|--|
| 198                                                                                   | 0x0C6       | Non-Volatile Memory Subsystem Controller Revision Code |  |  |
| 199                                                                                   | 0x0C7       | Reference Raw Card Used                                |  |  |
| 200                                                                                   | 0x0C8       | Module Characteristics                                 |  |  |
| 201~202                                                                               | 0x0C9~0x0CA | Hybrid Module Media Types                              |  |  |
| 203                                                                                   | 0x0CB       | Maximum Non-Volatile Memory Initialization Time        |  |  |
| 204~205                                                                               | 0x0CC~0x0CD | Function 0 Format Interface Descriptor                 |  |  |
| 206~207                                                                               | 0x0CE~0x0CF | Function 1 Format Interface Descriptor                 |  |  |
| 208~209                                                                               | 0x0D0~0x0D1 | Function 2 Format Interface Descriptor                 |  |  |
| 210~211                                                                               | 0x0D2~0x0D3 | Function 3 Format Interface Descriptor                 |  |  |
| 212~213                                                                               | 0x0D4~0x0D5 | Function 4 Format Interface Descriptor                 |  |  |
| 214~215                                                                               | 0x0D6~0x0D7 | Function 5 Format Interface Descriptor                 |  |  |
| 216~217                                                                               | 0x0D8~0x0D9 | Function 6 Format Interface Descriptor                 |  |  |
| 218~219                                                                               | 0x0DA~0x0DB | Function 7 Format Interface Descriptor                 |  |  |
| 220                                                                                   | 0x0DC       | SAVE_n Pullup Resistor                                 |  |  |
| 221~253                                                                               | 0x0DD~0x0FD | Reserved                                               |  |  |
| 254                                                                                   | 0x0FE       | CRC for SPD Block 1, Least Significant Byte            |  |  |
| 255                                                                                   | 0x0FF       | CRC for SPD Block 1, Most Significant Byte             |  |  |
| NOTE 1 1. CRC in bytes 254~255 covers all of SPD Block 1, bytes 128~255 (0x080~0x0FF) |             |                                                        |  |  |

Table 150 — Non-Volatile (NVDIMM-N) Hybrid Memory Parameters (Cont'd)

# 10.1.1 Byte 192 (0x0C0) (NVDIMM): Module Product Identifier, First Byte Byte 193 (0x0C1) (NVDIMM): Module Product Identifier, Second Byte

These bytes are defined and controlled by the memory module manufacturer to distinguish a specific product among their product offerings. Combined with the Module Manufacturer's ID Code in bytes 320~321 (0x14D~0x14E), creates a unique 32-bit code for each product type.

# 10.1.2 Byte 194 (0x0C2) (NVDIMM): Non-Volatile Memory Subsystem Controller Manufacturer's ID Code, First Byte Byte 195 (0x0C3) (NVDIMM): Non-Volatile Memory Subsystem Controller Manufacturer's ID Code, Second Byte

This two-byte field, shown in Table 151, indicates the manufacturer of the Non-Volatile Memory Subsystem controller, encoded as follows: the first byte is the number of continuation bytes indicated in JEP-106; the second byte is the last non-zero byte of the manufacturer's ID code, again as indicated in JEP-106.

Table 151 — Bytes 194 and 195, Non-Volatile Memory Subsystem Controller Manufacturer's ID Code

| Byte 195, Bits 7~0                        | Byte 194, Bit 7                   | Byte 194, Bits 6~0                                  |
|-------------------------------------------|-----------------------------------|-----------------------------------------------------|
| Last non-zero byte,<br>Flash Manufacturer | Odd Parity for Byte 194, bits 6~0 | Number of continuation codes,<br>Flash Manufacturer |
| See JEP-106                               |                                   | See JEP-106                                         |

**Example:** See SPD bytes 320~321, Section 8.5.1, for example manufacturer codes.

# 10.1.3 Byte 196 (0x0C4) (NVDIMM): Non-Volatile Memory Subsystem Controller Identifier, First Byte Byte 197 (0x0C5) (NVDIMM): Non-Volatile Memory Subsystem Controller Identifier, Second Byte

These bytes are defined and controlled by the non-volatile memory subsystem controller manufacturer to distinguish a specific product among their product offerings. In combination with the Non-Volatile Subsystem controller Manufacturer's ID Code in bytes 194~195 (0x0C2~0x0C3), they create a unique 32-bit code for each product type.

#### 10.1.4 Byte 198 (0x0C6) (NVDIMM): Non-Volatile Memory Subsystem Controller Revision Code

This byte refers to the non-volatile subsystem controller revision code. While the SPD specification will not attempt to define the format for this information, the individual non-volatile subsystem controller manufacturer may keep track of the revision code and its appropriate decode represented in this byte.

#### 10.1.5 Byte 199 (0x0C7) (NVDIMM): Reference Raw Card Used

This byte, shown in Tables 152 and 153, indicates which JEDEC reference design raw card was used as the basis for the module assembly, if any. Bits 4~0 describe the raw card and bits 6~5 describe the revision level of that raw card. Special raw card indicator, ZZ, is used when no JEDEC standard raw card was used as the basis for the design. Pre-production modules should be encoded as revision 0 in bits 6~5.

Table 152 — Byte 199 (0x0C7) (NVDIMM): Reference Raw Cards A through AL

| Bit 7                                | Bits 6~5                                                                                                                                                                       | Bits 4~0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Raw Card Extension         | Reference Raw Card Revision                                                                                                                                                    | Reference Raw Card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0 = Reference raw cards A through AL | 00 = revision 0 01 = revision 1 10 = revision 2 11 = revision 3 See byte 200 for extensions beyond revision 3; these bits must be coded as 11 for all revisions greater than 3 | When bit 7 = 0, 00000 = Reference raw card A 00001 = Reference raw card B 00010 = Reference raw card C 00011 = Reference raw card D 00100 = Reference raw card E 00101 = Reference raw card F 00110 = Reference raw card F 00110 = Reference raw card G 00111 = Reference raw card H 01000 = Reference raw card H 01001 = Reference raw card J 01001 = Reference raw card K 01010 = Reference raw card L 01011 = Reference raw card M 01100 = Reference raw card N 01101 = Reference raw card R 01111 = Reference raw card R 01111 = Reference raw card T 10000 = Reference raw card U 10001 = Reference raw card V 10010 = Reference raw card W 10011 = Reference raw card AA 10101 = Reference raw card AA 10101 = Reference raw card AA 10101 = Reference raw card AC 10111 = Reference raw card AC 10111 = Reference raw card AC 10111 = Reference raw card AF 11001 = Reference raw card AF 11001 = Reference raw card AH 11100 = Reference raw card AH 11101 = Reference raw card AK 11110 = Reference raw card AK 11110 = Reference raw card AK 11110 = Reference raw card AK 11111 = ZZ (no JEDEC reference raw card design used) |

Table 153 — Byte 199 (0x0C7) (NVDIMM): Reference Raw Cards AM through CB

| Bit 7                                 | Bits 6~5                                                                                                                                                                       | Bits 4~0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reference Raw Card Extension          | Reference Raw Card Revision                                                                                                                                                    | Reference Raw Card                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1 = Reference raw cards AM through CB | 00 = revision 0 01 = revision 1 10 = revision 2 11 = revision 3 See byte 200 for extensions beyond revision 3; these bits must be coded as 11 for all revisions greater than 3 | When bit 7 = 1,  00000 = Reference raw card AM  00001 = Reference raw card AN  00010 = Reference raw card AP  00011 = Reference raw card AP  00011 = Reference raw card AR  00100 = Reference raw card AT  00101 = Reference raw card AU  00110 = Reference raw card AW  00111 = Reference raw card AW  01000 = Reference raw card AW  01001 = Reference raw card BA  01010 = Reference raw card BB  01011 = Reference raw card BB  01011 = Reference raw card BB  01100 = Reference raw card BB  01110 = Reference raw card BF  01110 = Reference raw card BF  01111 = Reference raw card BB  10000 = Reference raw card BB  10001 = Reference raw card BB  10010 = Reference raw card BB  10010 = Reference raw card BB  10011 = Reference raw card BB  10010 = Reference raw card BB  10010 = Reference raw card BB  10010 = Reference raw card BB  10100 = Reference raw card BB  10101 = Reference raw card BB  10110 = Reference raw card BB  10111 = Reference raw card BB  11100 = Reference raw card BB  11001 = Reference raw card BB  11101 = Reference raw card BC  11111 = ZZ (no JEDEC reference raw card CB |

### 10.1.6 Byte 200 (0x0C8) (NVDIMM): Module Characteristics

This byte, shown in Table 154, contains additional information about the module characteristics. Bits 7~5 allow for extended raw card revision levels.

Table 154 — Byte 200 (0x0C8) (NVDIMM): Module Characteristics

| Bits 7~5                                                                                                                                                                                                                             | Bits 4~0                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Raw Card Extension                                                                                                                                                                                                                   | Reserved                         |
| 000 = raw card revisions 0 to 3; see byte 199 001 = raw card revision 4 010 = raw card revision 5 011 = raw card revision 6 100 = raw card revision 7 101 = raw card revision 8 110 = raw card revision 9 111 = raw card revision 10 | Reserved; must be coded as 00000 |

## 10.1.7 Bytes 201~202 (0x0C9~0x0CA) (NVDIMM): Hybrid Module Media Types

These bytes, shown in Table 155, define a media bit mask for all media types on the module. A setting of 1 in each bit position indicates the presence of that memory type on the module. The SPD is not considered as a media type in this context.

Byte 202 Byte 201 Bit Media Type Bit Media Type 0 Unknown/undefined 0 Reserved 1 **SDRAM** 1 Reserved 2 NAND Flash 2 Reserved 3 3 Byte-addressable non-volatile media Reserved 4 4 Reserved Reserved 5 Reserved 5 Reserved 6 Reserved 6 Reserved 7 7 Reserved Reserved

Table 155 — Bytes 201~202 (0x0C9~0x0CA) (NVDIMM): Hybrid Module Media Types

**Examples:** See Table 156.

Table 156 — Examples for Hybrid Module Media Types

| Module Type | Media Types                         | Byte 201  | Byte 202  |
|-------------|-------------------------------------|-----------|-----------|
| NVDIMM-N    | SDRAM, NAND Flash                   | 0000 0110 | 0000 0000 |
| NVDIMM-H    | SDRAM, NAND Flash                   | 0000 0110 | 0000 0000 |
| NVDIMM-F    | NAND Flash                          | 0000 0100 | 0000 0000 |
| NVDIMM-P    | Byte-addressable non-volatile media | 0000 1000 | 0000 0000 |

## 10.1.8 Byte 203 (0x0CB) (NVDIMM): Maximum Non-Volatile Memory Initialization Time

This byte, shown in Table 157, defines the maximum time required for all subsystem(s) to complete initialization from release of RESET or initialization programming of all subsystems present on the module, whichever is later, in seconds. If the initialization time is not known, this byte must be coded as 255 (0xFF).

Table 157 — Byte 203 (0x0CB) (NVDIMM): Maximum Non-Volatile Memory Initialization Time

|                              | Minimum Non-Volatile Memory Initialization Time Seconds |
|------------------------------|---------------------------------------------------------|
| Values defined from 0 to 254 |                                                         |

Examples: See Table 158.

Table 158 — Examples for Maximum Non-Volatile Memory Initialization Time

| Byte 203 | Hex  | Use                                        |  |
|----------|------|--------------------------------------------|--|
| 0        | 0x00 | No initialization time required            |  |
| 1        | 0x01 | 1 second                                   |  |
| 2        | 0x02 | seconds                                    |  |
|          |      |                                            |  |
| 255      | 0xFF | Initialization time not known or specified |  |

### 10.1.9 Bytes 204~219 (0x0CC~0x0DB) (NVDIMM): Function Interface Descriptors

These sets of 2 bytes, shown in Table 159, define the functions available on this module plus the location in the SPD Extended Function Parameters block of the information specific to each function.

Table 159 — Bytes 204~219 (0x0CC~0x0DB) (NVDIMM): Function Interface Descriptors

| Descriptor                      | Least S | ignificant Byte | Most Significant Byte |       |
|---------------------------------|---------|-----------------|-----------------------|-------|
| Function 0 Interface Descriptor | 204     | 0x0CC           | 205                   | 0x0CD |
| Function 1 Interface Descriptor | 206     | 0x0CE           | 207                   | 0x0CF |
| Function 2 Interface Descriptor | 208     | 0x0D0           | 209                   | 0x0D1 |
| Function 3 Interface Descriptor | 210     | 0x0D2           | 211                   | 0x0D3 |
| Function 4 Interface Descriptor | 212     | 0x0D4           | 213                   | 0x0D5 |
| Function 5 Interface Descriptor | 214     | 0x0D6           | 215                   | 0x0D7 |
| Function 6 Interface Descriptor | 216     | 0x0D8           | 217                   | 0x0D9 |
| Function 7 Interface Descriptor | 218     | 0x0DA           | 219                   | 0x0DB |

Each descriptor encodes the information depicted in Table 160:

Table 160 — Function Interface Descriptor

|                                                                                                                                                                                                                                                              | Most Significant B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Leas         | Least Significant Byte |                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------|-----------------------------------------------------------------------|
| Bit 15                                                                                                                                                                                                                                                       | Bit 15 Bit 14 Bits 13~10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |              | Bits 9~5               | Bits 4~0                                                              |
| Implemented                                                                                                                                                                                                                                                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Block Offset | Function Class         | Function Interface                                                    |
| Bit 15                                                                                                                                                                                                                                                       | 0 = Not implement<br>1 = Implemented                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ed           | *                      |                                                                       |
| Bit 14                                                                                                                                                                                                                                                       | Reserved; must be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | coded as 0   | *                      |                                                                       |
| Bits 13~10                                                                                                                                                                                                                                                   | Offset of additional information in Extended Function Parameter Block. Calculate as: 256 + (Block Offset * 4). Field shall have value of 0000 if there is no additional information in the Extended Function Parameter Block.  Block Offset values shall be contiguous from one Function Interface Descriptor to the next. If a Function Interface Descriptor N has information in the Extended Function Parameter Block, size of Extended Function Parameter Block for Function Interface Descriptor N is ((Block Offset Function Interface Descriptor N+1 – Block Offset Function Interface Descriptor N+1 is next Function Interface Descriptor That has a non-zero Block Offset value. |              |                        | 0000 if there is lock. face Descriptor in the Parameter ion Interface |
| Bits 9~5                                                                                                                                                                                                                                                     | See table for Function Classes and Function Interfaces                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              |                        |                                                                       |
| Bits 4~0                                                                                                                                                                                                                                                     | See table for Function Classes and Function Interfaces                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              |                        |                                                                       |
| NOTE 1 When bit 15 = 0, all other bits in the descriptor must also be coded as 0  NOTE 2 Block Offset granularity of 4 bytes may require rounding up to the next available byte in the Extended Function Parameter Block; unused bytes must be coded as 0x00 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |                        |                                                                       |

The Function Class and Function Interface are related as shown in Table 161:

Table 161 — Function Classes and Function Interfaces

| Function<br>Class<br>Bits 9~5 | Function                       | Definition                                                                                                                                                                                                                 | Function Interface<br>Bits 4~0                                                                                                      |
|-------------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 00 000                        | Undefined function             | Undefined                                                                                                                                                                                                                  | 0 0000 = Proprietary interface All other codes reserved                                                                             |
| 00 001                        | Byte addressable energy backed | A function containing byte addressable persistent memory whose persistence is achieved through the use of DRAM, nonvolatile memory (e.g., Flash) and an energy source. Only the DRAM portion is addressable by the system. | 0 0000 = Proprietary interface<br>0 0001 = JESD245 Byte Addressable<br>Energy Backed Function Interface<br>All other codes reserved |

| 00 010 | Block addressed                       | A function containing persistent memory that requires block-oriented access.                                                                                              | 0 0000 = Proprietary interface<br>0 0001 = Block Addressed Function<br>Interface 1<br>All other codes reserved                   |
|--------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 00 011 | Byte addressable,<br>no energy backed | A function containing byte address-<br>able persistent memory. All of the<br>persistent memory is addressable<br>by the system. No external energy<br>source is required. | 0 0000 = Proprietary interface<br>0 0001 = Byte Addressable No Energy<br>Backed Function Interface 1<br>All other codes reserved |
| 00 100 | Transactional credit based            | This function class supports persistent memory or volatile memory options that have energy backed and non-energy backed variations.                                       | 0 0000 = Proprietary interface<br>0 0001 = Transactional Credit Based<br>Function Interface 1<br>All other codes reserved        |
| 00 101 | Block cached byte addressable         | A function containing byte address-<br>able persistent memory managed<br>via a block oriented cache mecha-<br>nism.                                                       | 0 0000 = Proprietary interface<br>0 0001 = Block Cached Byte Address-<br>able Function Interface 1<br>All other codes reserved   |

Table 161 — Function Classes and Function Interfaces (Cont'd)

### Example 1: See Table 162.

#### NVDIMM with two functions:

Function Interface Descriptor 0 = A byte addressable energy backed function class using the byte addressable energy backed function with a JESD245 standard interface. This function class defines 14 bytes in the SPD Extended Function Parameters block.

Function Interface Descriptor 1 = A block addressed function class using the block addressed function interface 1. This function class requires 23 bytes in the SPD Extended Function Parameters block.

| Function 0 Interface Descriptor |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|---------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Byte 205                        | Byte 204                        | Byte 204 Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 1000 0000                       | 0010 0001                       | Bit 15 = 1: Implemented  Bits 9~5 = 00001: Function Class is Byte addressable energy backed  Bits 4~0 = 00001: Function Interface is JESD245 Byte addressable energy backed  Interface  Bits 13~10 = 0000: Offset of Extended Function Parameters = 256 + 0 * 4 = 256 (0x100)  Implied by the example (i.e., 14 bytes used):  Extended Function block from 256 through 269 (0x100~0x10D) is defined  Extended Function block bytes 270, 271 not used (coded as 0x00) |  |  |  |  |  |
|                                 | Function 1 Interface Descriptor |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| <b>-</b>                        | <b>-</b>                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| Byte 207                        |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| -,                              | Byte 206                        | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| 1001 0000                       | 0100 0001                       | Bit 15 = 1: Implemented Bits 9~5 = 00010: Function Class is Block addressed Bits 4~0 = 00001: Function Interface is Block Addressed Function Interface 1 Bits 13~10 = 0100: Offset of Extended Function Parameters = 256 + 4 * 4 = 272 (0x110)  Implied by the example (i.e., 23 bytes used): Extended Function block from 272 through 294 (0x110~0x126) is defined Extended Function block byte 295 not used (coded as 0x00)                                        |  |  |  |  |  |
|                                 | -                               | Bit 15 = 1: Implemented Bits 9~5 = 00010: Function Class is Block addressed Bits 4~0 = 00001: Function Interface is Block Addressed Function Interface 1 Bits 13~10 = 0100: Offset of Extended Function Parameters = 256 + 4 * 4 = 272 (0x110)  Implied by the example (i.e., 23 bytes used): Extended Function block from 272 through 294 (0x110~0x126) is defined                                                                                                  |  |  |  |  |  |
|                                 | -                               | Bit 15 = 1: Implemented Bits 9~5 = 00010: Function Class is Block addressed Bits 4~0 = 00001: Function Interface is Block Addressed Function Interface 1 Bits 13~10 = 0100: Offset of Extended Function Parameters = 256 + 4 * 4 = 272 (0x110)  Implied by the example (i.e., 23 bytes used): Extended Function block from 272 through 294 (0x110~0x126) is defined Extended Function block byte 295 not used (coded as 0x00)                                        |  |  |  |  |  |

Table 162 — Example 1: NVDIMM with Two Functions

Example 2: See Table 163.

NVDIMM with three functions:

#### Release 29

#### 10.1.9 Bytes 204~219 (0x0CC~0x0DB) (NVDIMM): Function Interface Descriptors (Cont'd)

Function Interface Descriptor 0 = a byte addressable no energy backed function using a proprietary interface. This function class defines 14 bytes in the SPD Extended Function Parameters block.

Function Interface Descriptor 1 = a block addressed function (2) using a proprietary interface. This function class does not have any bytes in the SPD Extended Function Parameter block.

Function Interface Descriptor 2 = an undefined function using a proprietary interface. This function class defines 23 bytes in the SPD Extended Function Parameters block.

Table 163 — Example 1: NVDIMM with Three Functions

|           | Function 0 Interface Descriptor |                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|-----------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Byte 205  | Byte 204 Meaning                |                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| 1000 0000 | 0110 0000                       | Bit 15 = 1: Implemented Bits 9~5 = 00011: Function Class is Byte addressable no energy backed Bits 4~0 = 00000: Function Interface is Proprietary interface Bits 13~10 = 0000: Offset of Extended Function Parameters = 256 + 0 * 4 = 256 (0x100)                                                                                                                                       |  |  |  |  |
|           |                                 | Implied by the example (i.e., 14 bytes used):  Extended Function block from 256 through 269 (0x100~0x10D) is defined  Extended Function block bytes 270, 271 not used (coded as 0x00)                                                                                                                                                                                                   |  |  |  |  |
|           |                                 | Function 1 Interface Descriptor                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Byte 207  | Byte 206                        | Meaning                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 1000 0000 | 0100 0000                       | Bit 15 = 1: Implemented  Bits 9~5 = 00010: Function Class is Block addressed  Bits 4~0 = 00000: Function Interface is Proprietary interface  Implied by the example (i.e., no bytes used): No changes to Extended Function block  Bits 13~10 coded as 0000                                                                                                                              |  |  |  |  |
|           |                                 | Function 2 Interface Descriptor                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Byte 209  | Byte 208                        | Meaning                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 1001 0000 | 0000 0000                       | Bit 15 = 1: Implemented  Bits 9~5 = 00000: Function Class is Undefined  Bits 4~0 = 00000: Function Interface is Proprietary interface  Offset of Extended Function Parameters = 256 + 4 * 4 = 272 (0x110)  Implied by the example (i.e., 23 bytes used):  Extended Function block from 272 through 294 (0x110~0x126) is used  Extended Function block byte 295 not used (coded as 0x00) |  |  |  |  |
|           |                                 | Functions 3~7 Interface Descriptors                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| Byte n+1  | Byte n                          | Meaning                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 0000 0000 | 0000 0000                       | Bit 15 = 0: Not Implemented; all other bits must be coded as 0                                                                                                                                                                                                                                                                                                                          |  |  |  |  |

### 10.1.10 Bytes 220 (0x0DC) (NVDIMM): SAVE\_n Pullup Resistor

This byte, shown in Table 164, documents the presence and value of a pullup resistor to 2.5 V on the SAVE\_n pin on the NVDIMM, rounded to the nearest kilohm.

Table 164 — Byte 220: SAVE n Pullup Resistor

| Bit 7                                                                       | Bits 6~0                                                                                                                                                                            |
|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pullup Present                                                              | Pullup Resistor Value in K $\Omega$                                                                                                                                                 |
| 0 = NVDIMM does not have a pullup resistor 1 = NVDIMM has a pullup resistor | $0000000 = \text{No resistor installed} \\ 0000001 = 1 \text{ K}\Omega \\ 0000010 = 2 \text{ K}\Omega \\ \\ 11111110 = 126 \text{ K}\Omega \\ 11111111 = \text{Other pullup value}$ |

Examples: see Table 165.

Table 165 — Examples of SAVE n Pullup Resistor

| Bit 7 | Bits 6~0 | Value | Usage                             |  |  |
|-------|----------|-------|-----------------------------------|--|--|
| 0     | 0000000  | 0     | No pullup resistor installed      |  |  |
| 1     | 0000010  | 2 ΚΩ  | 2 KΩ pullup resistor installed    |  |  |
| 1     | 0100101  | 37 KΩ | 37.4 KΩ pullup resistor installed |  |  |

#### 10.1.11 Bytes 221~253 (0x0DD~0x0FD) (NVDIMM):

Reserved, must be coded as 0x00

# 10.1.12 Bytes 254 (0x0FE) (NVDIMM): Cyclical Redundancy Code (CRC) for SPD Block 1, Least Significant Byte

Bytes 255 (0x0FF) (NVDIMM): Cyclical Redundancy Code (CRC) for SPD Block 1, Most Significant Byte

This two-byte field contains the calculated CRC for bytes 128~253 (0x080~0x0FD) in the SPD. See bytes 126~127 for coding example.

# 11 Extended Function Parameter Block (EXFUNC): Bytes 256~319 (0x100~0x13F)

This section contains zero or more blocks of extended function and interface protocol parameter sets for Hybrid memory modules. The blocks of parameters are contiguous in storage, and the index into this block is stored in the Offset descriptor field for each function type. Granularity of extended parameter blocks is a multiple 4 bytes; unused bytes in a block must be coded as 0x00.

The definition of each parameter block is shown here based on relative addressing within this SPD parameter block, i.e., the beginning address of the parameter block is calculated as:

256 + (4 \* Extended Parameter Block Offset for that function)

#### Example:

Function 0 offset = 0, length = 14: byte n = 256, n+1 = 257, ... bytes 268, 269 = 0x00 Function 1 offset = 16, length = 23: byte n = 270, n+1 = 271, ... byte 293 = 0x00 Function 2 offset = 40, length = 9: byte n = 296, n+1 = 297, ... bytes  $305\sim307=0x00$  Functions  $3\sim7$  = not implemented

# 11.1 Extended Function Parameter Block for Transactional Credit Based NVDIMM (TRANS)

This section defines the encoding of Extended Function Parameter SPD bytes, shown in Table 166, when a Function Interface Descriptor Function Class bits 9~5 contains 00100.

Table 166 — Extended Function Parameter Block for Transactional Credit Based NVDIMM (TRANS)

| Byte Number |        | Function Described                  |  |  |  |
|-------------|--------|-------------------------------------|--|--|--|
| n+0         | n+0x00 | Module Storage Capacity, First Byte |  |  |  |
| n+1         | n+0x01 | Module Storage Capacity, First Byte |  |  |  |
| n+2         | n+0x02 | XREAD Maximum Time                  |  |  |  |
| n+3         | n+0x03 | PWRITE Maximum Time                 |  |  |  |
| n+4         | n+0x04 | READ STATUS Maximum Time            |  |  |  |
| n+5         | n+0x05 | FLUSH Maximum Time                  |  |  |  |
| n+6         | n+0x06 | RESET Read Identifier Maximum Time  |  |  |  |
| n+7         | n+0x07 | Volatile Memory Modes               |  |  |  |

Table 166 — Extended Function Parameter Block for Transactional Credit Based NVDIMM (TRANS) (Cont'd)

| Byte Number |        | Function Described                                                                    |  |  |
|-------------|--------|---------------------------------------------------------------------------------------|--|--|
| n+8         | n+0x08 | Minimum Read Ready to Send Delay Time (t <sub>RRSE</sub> min), Least Significant Byte |  |  |
| n+9         | n+0x09 | Minimum Read Ready to Send Delay Time (t <sub>RRSE</sub> min), Most Significant Byte  |  |  |
| n+10        | n+0x0A | Fine offset for Minimum Read Ready to Send Delay Time (t <sub>RRSE</sub> min)         |  |  |
| n+11        | n+0x0B | Module Characteristics, First Byte                                                    |  |  |
| n+12        | n+0x0C | Module Characteristics, Second Byte                                                   |  |  |
| n+13        | n+0x0D | Module Characteristics, Third Byte                                                    |  |  |
| n+14        | n+0x0E | Module Characteristics, Fourth Byte                                                   |  |  |
| n+15        | n+0x0F | Module Characteristics, Fifth Byte                                                    |  |  |

## 11.1.1 Byte n+0~n+1 (TRANS): Module Storage Capacity

These two bytes define the capacity of the non-volatile storage on the NVDIMM accessible via the transactional protocol. The capacity is encoded as shown in Table 167.

Table 167 — Bytes n+0~n+1: Module Storage Capacity

| Byte n+1 (Most Sig                                                   | nificant Byte)                                   | Byte n+0 (Least Significant Byte) |                                                                                                                                                                    |  |
|----------------------------------------------------------------------|--------------------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits 15~14                                                           | Bits 15~14 Bits                                  |                                   | Bits 3~0                                                                                                                                                           |  |
| Capacity Base                                                        | Сара                                             | city Digits                       | Capacity, Tenths                                                                                                                                                   |  |
| 00 = Megabytes<br>01 = Gigabytes<br>10 = Terabytes<br>11 = Petabytes | Values from 0 to 999<br>All other values reserve | ed                                | 0000 = 0<br>0001 = 0.1<br>0010 = 0.2<br>0011 = 0.3<br>0100 = 0.4<br>0101 = 0.5<br>0110 = 0.6<br>0111 = 0.7<br>1000 = 0.8<br>1001 = 0.9<br>All other codes reserved |  |

Examples: see Table 168

Table 168 — Examples of Bytes n+1, n+0: Module Storage Capacity

| Code                 | Hex    | Meaning                          |
|----------------------|--------|----------------------------------|
| 01 00 1000 0000 0000 | 0x2800 | Module storage capacity = 128 GB |
| 10 00 0000 0001 0000 | 0x8010 | Module storage capacity = 1 TB   |
| 10 00 0000 0001 0101 | 0x8015 | Module storage capacity = 1.5 TB |
| 00 11 0010 0000 0000 | 0x3200 | Module storage capacity = 800 MB |

### 11.1.2 Bytes n+2~n+6 (TRANS): Command Maximum Time

These bytes, shown in Table 169, document the maximum execution time for certain functions. This may be used by the host controller to timeout if operations take longer than expected to complete.

|          | Bits 7~6    | Bit 5 | Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 |              |            |   |                  |
|----------|-------------|-------|-------------------------------|--------------|------------|---|------------------|
|          | Rsvd        |       | Maximum Time Parameter        |              |            |   | Units            |
| Byte n+2 |             |       | XREA                          | D Maximum    | Time       |   |                  |
| Byte n+3 | Reserved;   |       | PWRI                          | TE Maximun   | n Time     |   |                  |
| Byte n+4 | must be     |       | READ ST                       | ATUS Maxir   | num Time   |   | 0 = ns<br>1 = μs |
| Byte n+5 | coded as 00 |       | FLUS                          | H Maximum    | Time       |   | ,,,,             |
| Byte n+6 |             | R     | RESET Read                    | Identifier M | aximum Tim | е |                  |

Table 169 — Bytes n+2~n+6: Command Maximum Times

Each Maximum Time value is a 5-bit quantity, n, and units are nanoseconds or microseconds. The Maximum Time value is calculated as  $2^n$  in unit values.

Examples: see Table 170.

Table 170 — Examples of Bytes n+2~n+6: Command Maximum Times

| Timeout Setting | Units | Maximum Time Value            |
|-----------------|-------|-------------------------------|
| 00000           | 0     | 2 <sup>0</sup> = 1 ns         |
| 00001           | 0     | 2 <sup>1</sup> = 2 ns         |
| 01000           | 0     | 2 <sup>16</sup> = ~66 μs      |
| 00000           | 1     | 2 <sup>0</sup> = 1 μs         |
| 00001           | 1     | 2 <sup>1</sup> = 2 μs         |
| 01000           | 1     | 2 <sup>16</sup> = ~66 ms      |
| 11111           | 1     | 2 <sup>31</sup> = ~36 minutes |

## 11.1.3 Byte n+7 (TRANS): Volatile Memory Modes

This byte, shown in Table 171, documents whether certain optional features are enabled in the module functionality in the volatile memory mode of operation.

Table 171 — Byte n+7: Volatile Memory Mode

| Bit 7                              | Bit 6                                                                  | Bit 5                                                            | Bit 4                                                                | Bit 3                                                                                                     | Bits 2~0                                |
|------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------|
| Rsvd                               | PWRITE Command IOP Command Disable Disable                             |                                                                  | FLUSH Command<br>Disable                                             | Fixed Length<br>XREAD Com-<br>mand                                                                        | Rsvd                                    |
| Reserved,<br>must be<br>coded as 0 | 0 = PWRITE command<br>supported<br>1 = PWRITE command<br>not supported | 0 = IOP command<br>supported<br>1 = IOP command<br>not supported | 0 = FLUSH command<br>supported<br>1 = FLUSH command<br>not supported | 0 = data packet<br>length is<br>programmed in<br>XREAD command<br>1 = Fixed 64 byte<br>data packet length | Reserved,<br>must be<br>coded as<br>000 |

#### 11.1 Extended Function Parameter Block for Transactional Credit Based NVDIMM (TRANS) (Cont'd)

# 11.1.4 Byte n+8 (TRANS): Minimum Read Ready to Send Delay Time (t<sub>RRSE</sub>min), Least Significant Byte Byte n+9 (TRANS): Minimum Read Ready to Send Delay Time (t<sub>RRSE</sub>min), Most Significant Byte

This byte, shown in Table 172, documents the minimum required timing between RD\_RDY and the following SEND for an XREAD command, or for an SREAD command which results in a cache miss. This value comes from the DDR4 NVDIMM-P Specification. The most significant bit is Bit 7 of Byte n+9, and the least significant bit is Bit 0 of Byte n+8.

Table 172 — Byte n+9 Bits 7~0, Byte n+8 Bits 7~0

|                            | Minimum Read Ready to Send Latency Time (t <sub>RRSE</sub> min)  MTB Units |  |  |  |
|----------------------------|----------------------------------------------------------------------------|--|--|--|
| Values defined from 1 to 6 | Values defined from 1 to 65535                                             |  |  |  |

If  $t_{RRSE}$ min cannot be divided evenly by the MTB, this byte must be rounded up to the next larger integer and the Fine Offset for  $t_{RRSE}$ min (SPD byte TRANS n+10) used for correction to get the actual value.

Examples: tbd

# 11.1.5 Byte n+10 (TRANS): Fine offset for minimum Read Ready to Send Delay Time (t<sub>RRSE</sub>min)

This byte modifies the calculation of SPD Bytes (TRANS) n+9 and n+8 with a fine correction using FTB units. The value of t<sub>RRSE</sub>min comes from the NVDIMM-P specification. This value is a two's complement multiplier for FTB units, ranging from +127 to -128.

Examples: For Two's Complement encoding, see Relating the MTB and FTB.

### 11.1.6 Bytes n+11~n+15 (TRANS): Module Characteristics

These bytes, shown in Table 173, document whether certain optional features are enabled in the module functionality in standard operation.

Table 173 — Bytes n+11~n+15: Module Characteristics

|           | Bit 7                                                                     | Bit 6 | Bit 5 | Bit 4             | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|---------------------------------------------------------------------------|-------|-------|-------------------|-------|-------|-------|-------|
| Byte n+11 | Maximum Write Credits bits 7~0                                            |       |       |                   |       |       |       |       |
| Byte n+12 | Maximum Persistent Write Credits bits 3~0 Maximum Write Credits bits 11~8 |       |       | 11~8              |       |       |       |       |
| Byte n+13 | Maximum Persistent Write Credits bits 11~4                                |       |       |                   |       |       |       |       |
| Byte n+14 | Maximum Read Credits                                                      |       |       |                   |       |       |       |       |
| Byte n+15 | Reserved WGID Reporting                                                   |       |       | WGID<br>Reporting |       |       |       |       |

Credits are in 64-byte units. Values for Write and Persistent Write credits are 1 to 4096. Outstanding Read Commands allowed are from 1 to 256.

WGID Reporting:

- 0 = Reporting is supported and enabled via mode register
- 1 = WGID reporting is not supported and persistent writes must be confirmed in order

### 11.1.7 Application notes for Transactional Credit Based NVDIMMs

When programming an SPD for use in an NVDIMM supporting this function, the following guidelines are followed for applying the SPD overlay system. Some bytes in SPD block 0 apply, other bytes do not. Table 174 documents bytes in SPD block 0 that must be programmed to represent the NVDIMM.

Table 174 — Bytes in SPD block 0 that must be programmed to represent the NVDIMM

| Byte  | Description                                                       | Transactional Credit Based NVDIMM Definition                                                                                                                                              |  |  |
|-------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0     | Number of Serial PD Bytes Written / SPD Device Size               | Standard programming                                                                                                                                                                      |  |  |
| 1     | SPD Revision                                                      | Standard programming                                                                                                                                                                      |  |  |
| 2     | Key Byte / DRAM Device Type                                       | Must be programmed as 12 (0x0C), DDR4 SDRAM                                                                                                                                               |  |  |
| 3     | Key Byte / Module Type                                            | NVDIMM-P based on RDIMM interface: Programmed as 0xA1 NVDIMM-P based on LRDIMM interface: Programmed as 0xA4                                                                              |  |  |
| 12    | Module Organization                                               | Must be programmed as 0x00, symmetrical one package rank with x4 interface.                                                                                                               |  |  |
| 13    | Module Memory Bus Width                                           | Must be programmed as 0x0B, 64 bit primary bus with 8 bit extension                                                                                                                       |  |  |
| 14    | Module Thermal Sensor                                             | Must be programmed as 0x80, thermal sensor compatible with TSE2004av specifications incorporated onto module                                                                              |  |  |
| 15    | Extended Module Type                                              | Must be programmed as 0x00, not used                                                                                                                                                      |  |  |
| 17    | Timebases                                                         | Standard programming                                                                                                                                                                      |  |  |
| 18    | SDRAM Minimum Cycle Time (t <sub>CKA-VG</sub> min)                | Standard programming                                                                                                                                                                      |  |  |
| 19    | SDRAM Maximum Cycle Time (t <sub>CKA-VG</sub> max)                | Standard programming                                                                                                                                                                      |  |  |
| 20    | CAS Latencies Supported, First Byte                               | Standard programming                                                                                                                                                                      |  |  |
| 21    | CAS Latencies Supported, Second<br>Byte                           | Standard programming                                                                                                                                                                      |  |  |
| 22    | CAS Latencies Supported, Third Byte                               | Standard programming                                                                                                                                                                      |  |  |
| 23    | CAS Latencies Supported, Fourth Byte                              | Standard programming                                                                                                                                                                      |  |  |
| 24    | Minimum CAS Latency Time (t <sub>AA</sub> min)                    | $\label{eq:minimum} \begin{array}{l} \mbox{Minimum READ SEND time, $t_{SEND\_RD}$min.} \\ \mbox{Used to calculate $t_{SEND\_RD}$min, $t_{SEND\_WR}$min, $t_{SEND\_SRD}$min.} \end{array}$ |  |  |
| 60~77 | Connector to SDRAM Bit Mapping                                    | Standard programming                                                                                                                                                                      |  |  |
| 123   | Fine Offset for Minimum CAS Latency<br>Time (t <sub>AA</sub> min) | Standard programming; applies to SPD Byte 24, t <sub>SEND_RD</sub> min.                                                                                                                   |  |  |
| 124   | Fine Offset for SDRAM Maximum Cycle Time (t <sub>CKAVG</sub> max) | Standard programming                                                                                                                                                                      |  |  |
| 125   | Fine Offset for SDRAM Minimum Cycle Time (t <sub>CKAVG</sub> min) | Standard programming                                                                                                                                                                      |  |  |
| 126   | CRC for Base Configuration Section,<br>Least Significant Byte     | Standard programming                                                                                                                                                                      |  |  |
| 127   | CRC for Base Configuration Section,<br>Most Significant Byte      | Standard programming                                                                                                                                                                      |  |  |

NVDIMMs supporting the Transactional Credit Based function utilize a system bus interface based on either the RDIMM or LRDIMM interface standards. After processing SPD block 0, systems must overlay functionality from SPD Block 1 lower half, bytes 128~191, using byte specifications from Section 9.2 for Registered Memory Module Types, or from Section 9.3 for Load Reduced Memory Module Types.

#### 11.1.7 Application notes for Transactional Credit Based NVDIMMs (Cont'd)

SPD bytes 192~255 for Hybrid Memory Module Types are applied as the next overlay, followed by Extended Function Parameter Bytes, as described in this section.

## 11.2 Extended Function Parameter Block for Block Addressed NVDIMM (BLOCK)

This section defines the encoding of Extended Function Parameter SPD bytes when a Function Interface Descriptor Function Class bits 9~5 contain 00010 or 00101, as shown in Table 175.

Table 175 — Extended Function Parameter Block for Block Addressed NVDIMM (BLOCK)

| Byte Number |        | Function Described                   |  |
|-------------|--------|--------------------------------------|--|
| n+0         | n+0x00 | Module Characteristics               |  |
| n+1         | n+0x01 | Module Storage Capacity, First Byte  |  |
| n+2         | n+0x02 | Module Storage Capacity, Second Byte |  |

### 11.2.1 Byte n (BLOCK): Module Characteristics

This byte, shown in Table 176, contains additional information about the module characteristics including the interleave capability and energy backup of the NVDIMM. The interleave stride indicates either the NVDIMM cannot be interleaved and must be placed in a contiguous address space or it can be interleaved with other DIMMs on a stride greater than or equal to the encoded value.

Table 176 — Byte n: Module Characteristics

| Bit 7                                                              | Bit 6                                                                                                                     | Bits 5~0                                                                                                                                                                                                                                        |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Energy Backed                                                      | Interleave Capable                                                                                                        | Interleave Stride ≥ 2 <sup>n</sup>                                                                                                                                                                                                              |
| 0 = DIMM does not have energy backup<br>1 = DIMM has energy backup | 0 = DIMM cannot be interleaved<br>1 = DIMM can be interleaved on a<br>stride greater than or equal to 2 <sup>Stride</sup> | 000000 = $2^0$ : Stride ≥ 1 byte<br>000001 = $2^1$ : Stride ≥ 2 bytes<br><br>001111 = $2^{15}$ : Stride ≥ 32 KB<br>010000 = $2^{16}$ : Stride ≥ 64 KB<br>010001 = $2^{17}$ : Stride ≥ 128 KB<br><br>111111 = $2^{63}$ : Stride ≥ $2^{63}$ bytes |

Examples: See Table 177.

Table 177 — Examples for Byte n: Module Characteristics

| Code      | Hex  | Meaning                                                                                 |  |
|-----------|------|-----------------------------------------------------------------------------------------|--|
| 11 010000 | 0xD0 | Energy backup is available DIMM can be interleaved ≥ 2 <sup>16</sup> (64 KB) boundaries |  |
| 00 000000 | 0x00 | Energy backup is not available DIMM interleaving not supported                          |  |

#### 11.2.2 Byte n + 1 ~ n + 2 (BLOCK): Module Storage Capacity

These 2 bytes define the offered capacity of the block storage on the NVDIMM. The capacity is encoded as shown in Table 178:

Byte n+2 (Most Significant Byte) Byte n+1 (Least Significant Byte) Bits 3~0 Bits 15~14 Bits 13~4 Capacity Base Capacity Digits Capacity, Tenths 00 = Mega Bytes Values from 0 to 999 0000 = 001 = Giga Bytes All other values reserved 0001 = 0.10010 = 0.210 = Tera Bytes 11 = Peta Bytes 0011 = 0.30100 = 0.40101 = 0.50110 = 0.60111 = 0.71000 = 0.81001 = 0.9All other codes reserved

Table 178 — Bytes n+2, n+1: Module Storage Capacity

**Examples:** See Table 179.

Table 179 — Examples for Bytes n+2, n+1: Module Storage Capacity

| Code                 | Hex    | Meaning                          |
|----------------------|--------|----------------------------------|
| 01 00 1000 0000 0000 | 0x2800 | Module storage capacity = 128 GB |
| 10 00 0000 0001 0000 | 0x8010 | Module storage capacity = 1 TB   |
| 10 00 0000 0001 0101 | 0x8015 | Module storage capacity = 1.5 TB |
| 00 11 0010 0000 0000 | 0x3200 | Module storage capacity = 800 MB |

# 11.3 Extended Function Parameter Block for Byte Addressable No Energy Backed NVDIMM (BYTE-NOE)

This section defines the encoding of Extended Function Parameter SPD bytes when a Function Interface Descriptor Function Class bits 9~5 contain 00011:

Byte n (BYTE-NOE)

Byte n + 1 (BYTE-NOE)

Byte n + 2 (BYTE-NOE)

# 11.3.1 Bytes 318 (0x13E) (EXFUNC): Cyclical Redundancy Code (CRC) for SPD Block 2 lower half, Least Significant Byte

Bytes 319 (0x13F) (EXFUNC): Cyclical Redundancy Code (CRC) for SPD Block 2 lower half, Most Significant Byte

This two-byte field contains the calculated CRC for bytes  $256\sim318$  ( $0x100\sim0x13D$ ) in the SPD. See bytes  $126\sim127$ , Section 8.1.53, for coding example.